大橙子网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这期内容当中小编将会给大家带来有关java中常用集合的使用方法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
沙依巴克网站建设公司创新互联公司,沙依巴克网站设计制作,有大型网站制作公司丰富经验。已为沙依巴克近1000家提供企业网站建设服务。企业网站搭建\成都外贸网站制作要多少钱,请找那个售后服务好的沙依巴克做网站的公司定做!
在java中集合主要分为:List,Set,Map三种,其中List与Set是继承自Collection,而Map不是。
List与Set的区别:List中的元素有存放顺序,并且可以存放重复元素,检索效率高,插入删除效率低,Set没有存放顺序,而且不可以存放重复元素,后来的元素会把前面重复的元素替换掉,检索效率低,插入删除效率高。(Set存储位置是由它的HashCode码决定的,所以它存储的对象必须有equals()方法,而且Set遍历只能用迭代,因为它没有下标。)
1、最常用的集合:ArrayList
特点:ArrayList集合中元素存储的位置是连续的,所以查询起来会比较快捷,但是执行插入删除操作会比较麻烦一点,会引起其他元素位置的变化。
注意:list中存储的是对象的引用,而不是对象本身。如果不清楚这一点会在这里有个坑,例如:
有人为了节省优化代码,节省虚拟机内存会这么写代码:
List> list=new ArrayList<>(); List
list2=new ArrayList<>(); for(int i=0;i<10;i++){ list2.add(""+i); list.add(list2); list2.clear(); }
这样写虽然可以一个对象重复使用,但是,list存储的是对象的引用,当list2.clear();的时候,list中的list2也会clear,这样最后得到的就只能是一堆空的集合了。
2、与最常用集合相反的集合:LinkedList
LinkedList与ArrayList是互补的,所以ArrayList的优点就是LinkedList的缺点,ArrayList的缺点就是LinkedList的优点。
特点:LinkedList中元素位置是任意的,所以执行插入删除操作效率较高,查询效率较低。
3、与一般集合都相反的集合:Vector
为什么说它与一般集合都相反呢?因为它是一种老的动态数组,很多方法都用synchonized修饰,所以它是线程安全得,而一般集合是线程不安全得。
特点:多个线程同时访问不会发生不确定的结果,但是它的效率会比较低,如果要考虑线程安全的话可以用它。
4、Set中最常用的集合:HashSet
在用Set集合的时候我几乎用的都是HashSet,HashSet是使用Hash表实现的,集合里面的元素是无序得,可以有null值,但是不能有重复元素。
特点:因为相同的元素具有相同的hashCode,所以不能有重复元素
5、Set中第二常用的集合:TreeSet
TreeSet是用二叉树结构实现的集合
特点:集合中的元素是有顺序得,不允许放入null,同样不能放入重复元素。
6、第二常用的集合:HashMap
经常遇到需要使用键值对存储的场景,而HashMap是用得最多的一种键值对存储的集合。
特点:HashMap允许空键值,并且它是非线程安全的,所以插入、删除和定位元素会比较快。
7、一些不太常用的Map集合:TreeMap,HashTable
TreeMap是基于红黑树实现的,适用于按自然顺序火兹定于顺序遍历key。
HashTable是基于HashCode实现的,但它是线程安全的,所以会比HashMap效率低,而且不允许null值。
上述就是小编为大家分享的java中常用集合的使用方法了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注创新互联行业资讯频道。