美文网首页Spring-Boot未分类
Java Collection的使用

Java Collection的使用

作者: alonwang | 来源:发表于2018-08-31 12:53 被阅读14次

    1. 数组转集合 Arrays.asList(T... var0)

    请注意这里返回的List是Arrays的静态内部类

     private static class ArrayList<E> extends AbstractList<E> implements RandomAccess, Serializable {
    }
    

    它是unModified(不可修改的),传输时可能会导致序列化错误(如果你使用了诸如kryo等序列化框架),如果希望获得的集合是可修改的,最好的做法是这样

    List<String> argList = new ArrayList<String>(Arrays.asList(args));
    

    2. 数组和集合的区别

    集合并不仅仅是数组的拓展,要明白数组与集合的区别需要弄清楚顺序 和位置 的不同,随机访问时,对于数组是基于位置访问,对集合时基于顺序的
    一个最浅显的例子,从集合中移除一个元素后,访问下一个元素下标不需要变化

    3. Iterator的妙用

    public interface Iterator<E> {
        boolean hasNext();
    
        E next();
    
        default void remove() {
            throw new UnsupportedOperationException("remove");
        }
    
        default void forEachRemaining(Consumer<? super E> var1) {
            Objects.requireNonNull(var1);
    
            while(this.hasNext()) {
                var1.accept(this.next());
            }
    
        }
    }
    
    
    1. Iterator.remove()支持从源集合中安全地删除对象
    2. Iterator 支持派生的兄弟成员。ListIterator,只存在于 List 中,支持在迭代期间向 List 中添加或删除元素,并且可以在 List 中双向滚动
    public interface ListIterator<E> extends Iterator<E> {
        boolean hasNext();
    
        E next();
    
        boolean hasPrevious();
    
        E previous();
    
        int nextIndex();
    
        int previousIndex();
    
        void remove();
    
        void set(E var1);
    
        void add(E var1);
    }
    

    4. 实现Iterable接口完成自定义功能

    public interface Iterable<T> {
        Iterator<T> iterator();
    
        default void forEach(Consumer<? super T> var1) {
            Objects.requireNonNull(var1);
            Iterator var2 = this.iterator();
    
            while(var2.hasNext()) {
                Object var3 = var2.next();
                var1.accept(var3);
            }
    
        }
    
        default Spliterator<T> spliterator() {
            return Spliterators.spliteratorUnknownSize(this.iterator(), 0);
        }
    }
    

    这里原作者使用了一个封装文件读取的例子,很有意思

    对象存入Map后,如果对其操作并影响到hashCode中的字段,会导致查找不到这个对象

    尽量不要用对象当做key字段,或者确保存入后不会进行修改

    使用sortedSet时确保compareTo==0和equals的行为保持一致

    摘取一段代码

    public class UsingSortedSet
    {
        public static void main(String[] args)
        {
            List<Person> persons = Arrays.asList(
                new Person("Ted", "Neward", 39),
                new Person("Ron", "Reynolds", 39),
                new Person("Charlotte", "Neward", 38),
                new Person("Matthew", "McCullough", 18)
            );
            SortedSet ss = new TreeSet(new Comparator<Person>() {
                public int compare(Person lhs, Person rhs) {
                    return lhs.getLastName().compareTo(rhs.getLastName());
                }
            });
            ss.addAll(perons);
            System.out.println(ss);
        }
    }
    

    最终获得的set只有三个元素,因为compare==0时即表示两个对象相同
    并且简单的声明两者相等还不够,因为以排序为目的的比较不同于以相等性为目的的比较:可以想象一下按姓排序时两个 Person 相等,但是其内容却并不相同。


    源码基于jdk1.8

    IBM5件事系列:https://www.ibm.com/developerworks/cn/views/java/libraryview.jsp?search_by=%E6%82%A8%E4%B8%8D%E7%9F%A5%E9%81%93%E7%9A%84+5+%E4%BB%B6%E4%BA%8B

    相关文章

      网友评论

        本文标题:Java Collection的使用

        本文链接:https://www.haomeiwen.com/subject/mlrswftx.html