• 2019-2-22


    Map.Entry 类使用简介(转)

     

    你是否已经对每次从Map中取得关键字然后再取得相应的值感觉厌倦?使用Map.Entry类,你可以得到在同一时间得到所有的信息。标准的Map访问方法如下:

    Set keys = map.keySet( );
    if(keys != null) {
    Iterator iterator = keys.iterator( );
    while(iterator.hasNext( )) {
    Object key = iterator.next( );
    Object value = map.get(key);
    ;....
    ;}
    }

    然后,这个方法有一个问题。从Map中取得关键字之后,我们必须每次重复返回到Map中取得相对的值,这是很繁琐和费时的。

    幸运的是,这里有一个更加简单的途径。Map类提供了一个称为entrySet()的方法,这个方法返回一个Map.Entry实例化后的对象集。接着,Map.Entry类提供了一个getKey()方法和一个getValue()方法,因此,上面的代码可以被组织得更符合逻辑。举例如下:

    Set entries = map.entrySet( );
    if(entries != null) {
    Iterator iterator = entries.iterator( );
    while(iterator.hasNext( )) {
    Map.Entry entry =iterator.next( );
    Object key = entry.getKey( );
    Object value = entry.getValue();
    ;....
    }
    }

    尽管增加了一行代码,我们却省略了许多对Map不必要的“get”调用。同时,提供给开发人员一个同时保持了关键字和其对应的值的类。Map.Entry同时也提供了一个setValue()方法,程序员可以使用它修改map里面的值。

    集合的安全性问题
    请问 ArrayList、HashSet、HashMap 是线程安全的吗?如果不是我想要线程安全的集合怎么办?


    我们都看过上面那些集合的源码(如果没有那就看看吧),每个方法都没有加锁,显然都是线程不安全的。话又说
    过来如果他们安全了也就没第二问了。
    在集合中 Vector 和 HashTable 倒是线程安全的。你打开源码会发现其实就是把各自核心方法添加上了
    synchronized 关键字。
    Collections 工具类提供了相关的 API,可以让上面那 3 个不安全的集合变为安全的。
    1. // Collections.synchronizedCollection(c)
    2. // Collections.synchronizedList(list)
    3. // Collections.synchronizedMap(m)
    4. // Collections.synchronizedSet(s)
    上面几个函数都有对应的返回值类型,传入什么类型返回什么类型。打开源码其实实现原理非常简单,就是将集
    合的核心方法添加上了 synchronized 关键字。

    如何判断栈的进出问题一个栈的输入序列为1 2 3 4 5,则下列序列中不可能是栈的输出序列的是( )A. 2 3 4 1
    解答:

    一个栈的输入序列为1 2 3 4 5,则下列序列中不可能是栈的输出序列的是( )
    A.2 3 4 1 5 B.5 4 1 3 2C.2 3 1 5 4 D.1 5 4 3 2
    这题就选B
    这样的题做多了就找出规律了
    先进1和2,2出栈进入3,3出栈,进入4,4出栈,1在出栈,5进,5出栈,所以是23415,A对
    进1和2,2出栈,进入3,3出栈,1出栈,进入4,在进入5,5出,4在出,就是23154,C对
    1进,1出,2345进,然后5432出,就是15432,D对
    B是错误,因为5要想出来,就必须五个数都要进栈,那么出来就一种结果是54321,答案是54132所以不对
    这种题找规律,就能做出来

    我们都知道栈是先进后出的,可以理解为桶状结构

  • 相关阅读:
    20.12.2 leetcode7
    20.12.1 leetcode34
    20.11.30 leetcode767
    20.11.29 leetcode976
    Codeforces632E 选择/小偷与商店 背包DP
    魔法少女 DP NG放的水
    逆反的01串 模拟 NG放的水
    最大数maxnumber bzoj1012 JSOI2008 单调队列
    组合数问题 vijos2006 NOIP2016 D2T1 杨辉三角 排列组合 前缀和
    信息传递 vijos1979 NOIP2015D1T2 强连通分量 tarjan模版题
  • 原文地址:https://www.cnblogs.com/erfsfj-dbc/p/10418478.html
Copyright © 2020-2023  润新知