基于Java中的数值和集合详解
数组array和集合的区别:
(1) 数值是大小固定的,同一数组只能存放一样的数据。
(2) java集合可以存放不固定的一组数据
(3) 若程序事不知道究竟需要多少对象,需要在空间不足时自动扩增容量,则需要使用容器类库,array不适用
数组转换为集合:
arrays.aslist(数组)
示例:
int[] arr = {1,3,4,6,6}; arrays.aslist(arr); for(int i=0;i<arr.length;i++){ system.out.println(arr[i]); }
集合转换为数组:
集合.toarray();
示例:
list list = new arraylist(); list.add("a"); list.add("b"); list.toarray(); system.out.println(list.tostring());
一、集合的体系结构:
list、set、map是这个集合体系中最主要的三个接口。 list和set继承自collection接口。 map也属于集合系统,但和collection接口不同。
set不允许元素重复。hashset和treeset是两个主要的实现类。set 只能通过游标来取值,并且值是不能重复的。
list有序且允许元素重复。arraylist、linkedlist和vector是三个主要的实现类。 arraylist 是线程不安全的, vector 是线程安全的,这两个类底层都是由数组实现的 linkedlist 是线程不安全的,底层是由链表实现的
map 是键值对集合。其中key列就是一个集合,key不能重复,但是value可以重复。 hashmap、treemap和hashtable是map的三个主要的实现类。 hashtable 是线程安全的,不能存储 null 值 hashmap 不是线程安全的,可以存储 null 值
二、list和arraylist的区别
1.list是接口,list特性就是有序,会确保以一定的顺序保存元素。
arraylist是它的实现类,是一个用数组实现的list.
map是接口,map特性就是根据一个对象查找对象.
hashmap是它的实现类,hashmap用hash表实现的map,就是利用对象的hashcode(hashcode()是object的方法)进行快速散列查找。(关于散列查找,可以参看<<数据结构>>)
2.一般情况下,如果没有必要,推荐代码只同list,map接口打交道。
比如:list list = new arraylist();
这样做的原因是list就相当于是一个泛型的实现,如果想改变list的类型,只需要:
list list = new linkedlist();//linkedlist也是list的实现类,也是arraylist的兄弟类
这样,就不需要修改其它代码,这就是接口编程的优雅之处.
另外的例子就是,在类的方法中,如下声明:
private void domyaction(list list){}
这样这个方法能处理所有实现了list接口的类,一定程度上实现了泛型函数.
3.如果开发的时候觉得arraylist,hashmap的性能不能满足你的需要,可以通过实现list,map(或者collection)来定制你的自定义类.
以上这篇基于java中的数值和集合详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
上一篇: 狸窝全能视频转换器剪切视频详细图文教程
下一篇: 吃鸡脚的好处你知道吗?吃鸡脚好处多多。