Array转ArrayList当需要把Array转成ArrayList的时候,开发人员经常这样做:List list = Arrays.asList(arr);Arrays.asList()会返回一个ArrayList,但是要特别注意,这个ArrayList是Arrays类的静态内部类,并不是java.util.ArrayList类。java.util.Arrays.ArrayL
ArrayList<String> list = new ArrayList<String>(Arrays.asList("a", "b", "c","d")); for (int i = 0; i < list.size(); i++) { list.remove(i); } System.out.println(list);
ArrayList<String> list = new ArrayList<String>(Arrays.asList("a", "b", "c","d")); Iterator<String> iter = list.iterator(); while (iter.hasNext()) { String s = iter.next(); if (s.equals("a")) { iter.remove(); } }
从算法的角度来讲,HashTable是一种数据结构名称。但是在Java中,这种数据结构叫做HashMap。HashTable与HashMap的一个主要的区别是HashTable是同步的,所以,通常来说,你会使用HashMap,而不是Hashtable。更多信息:HashMap vs. TreeMap vs. Hashtable vs. LinkedHashMap Top 10 questions about Map
publicstaticvoidadd(List list, Object o){ list.add(o); } publicstaticvoidmain(String[] args){ List<String> list = new ArrayList<String>(); add(list, 10); String s = list.get(0); }
运行以上代码将会抛出异常:Exception in thread "main" java.lang.ClassCastException: java.lang.Integer cannot be cast to java.lang.String at …使用原始类型集合非常危险,因为它跳过了泛型类型检查,是不安全的。另外,Set, Set, 和Set这三个有很大的不同,具体请看:类型擦除和Raw type vs. Unbounded wildcard。
访问级别
开发人员经常使用public修饰类字段,虽然这很容易让别人直接通过引用获取该字段的值,但这是一个不好的设计。根据经验,应该尽可能的降低成员属性的访问级别。相关阅读:public, default, protected, and private
ArrayList和LinkedList
为什么开发人员经常使用ArrayList和LinkedList,却不知道他们之间的区别,因为它们看起来很像。然而它们之间有着巨大的性能差异。简单的说,如果有大量的增加删除操作并且没有很多的随机访问元素的操作,应该首选LinkedList。相关阅读:ArrayList vs. LinkedList
String result=""; for(String s: arr){ result = result + s; }
另外,在有些其它情况下也是需要使用可变对象。例如往一个方法传入一个可变对象,然后收集多种结果,而不需要写太多的语法。另一个例子是排序和过滤:当然,你可以写一个方法来接收原始的集合,并且返回一个排好序的集合,但是那样对于大的集合就太浪费了。更多阅读:Why String is Immutable??Why we need mutable classes?