亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

Java Collection的使用

標簽:
Java

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 相等,但是其内容却并不相同。



作者:alonwang
链接:https://www.jianshu.com/p/72e03645fda1


點擊查看更多內容
TA 點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優質文章

正在加載中
  • 推薦
  • 評論
  • 收藏
  • 共同學習,寫下你的評論
感謝您的支持,我會繼續努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學

大額優惠券免費領

立即參與 放棄機會
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號

舉報

0/150
提交
取消