###集合,collection , map
*Array 数组。string[] s1 = new string[3];
*存储内容有区别,数组可以存储基本类型和对象类型,而集合只能存储对象。
*数组有长度限制,固定大小的数组,集合没有长度限制,大小不固定。
*数组的存储结构是存储单个数据。map可以存储key = value 建值对。形成了映射关联结构
###collection 集合
*数组转化为集合 Arrays.asList(students); //students是数组
*集合大小获取使用 list.size();
*集合对象获取 list.get(i); //获取集合中第一个元素
*集合转为数组 Student[] students2 = (Student[]) sList.toArray(new Student[sList.size()]);
*集合中添加元素 list.add();
###迭代器iterator,主要用于遍历集合
Iterator it = sList.iterator();//将集合转化为迭代器
while (it.hasNext()) { //判断是否存在下一个元素
Student st = it.next(); //返回下一个元素
st.info();
}
###泛型,1.5之前集合存储的数据会自动强转为object类型,这样就发生了类型的丢失,造成访问安全。 jdk1.5后新特性,解决集合容器数据安全问题,主要原理是在类声明时通过标识表示类中的具体对象型。
//这个说明容器list中存储学生student类型对象
List list = Arrays.asList(students);
###foreach增强型for循环 迭代容器数据
for(类型 变量:要迭代的容器){
变量操作
}
###ArrayList类型
*构建 new
*添加 add(元素)
*删除 remove(索引)
*更新 set(索引,元素)
###linkedList 对于堆栈和链表结构有对应的实现,所以自身包含新方法
*堆栈结构就是典型的 FILO 先进后出的结构。 例如:弹夹,最后压入的子弹第一个打出去。
*入栈(压栈)方法 push
*出栈(弹栈)方法 pop
###ArrayList 适用于查询和循环遍历 速度很快,LinkedList 适用于插入和删除,速度很快
###ArrayList和Vector 的区别,两者都是通过数组实现的。不同的是Vector支持线程同步,同一时刻只能一个线程访问,他是线程安全的,避免了多线程并发访问时的数据不一致问题(脏读写。)。但是同步花费代价太高,因此比ArrayList效率低,所以基本不在使用
###set 集合接口是collection接口的子类,不允许存储相同对象,如果添加相同对象,则添加失败。
*1.不保证数据存储的有序性(就是无序的)
*2.非线程安全
*3.可以添加null到集合
###set 判断两个对象是否相等不是使用的 == 比较,而是使用equals方法判断。
###自定义对象判断相等,需要重写hashcode()和eqauls()方法
####Map 双列 存储 key - value 主要实现类hashmap
####Map 特性 , key值不允许重复存储,可以将null作为key和value来用,无序存储
###2_集合框架(Map集合的功能概述)
*A:Map集合的功能概述
* a:添加功能
* V put(K key,V value):添加元素。
* 如果键是第一次存储,就直接存储元素,返回null
* 如果键不是第一次存在,就用值把以前的值替换掉,返回以前的值
* b:删除功能
* void clear():移除所有的键值对元素
* V remove(Object key):根据键删除键值对元素,并把值返回
* c:判断功能
* boolean containsKey(Object key):判断集合是否包含指定的键
* boolean containsValue(Object value):判断集合是否包含指定的值
* boolean isEmpty():判断集合是否为空
* d:获取功能
* Set> entrySet():
* V get(Object key):根据键获取值
* Set keySet():获取集合中所有键的集合
* Collection values():获取集合中所有值的集合
* e:长度功能
* int size():返回集合中的键值对的个数
###3_集合框架(Map集合的遍历之键找值)
*A:键找值思路:
* 获取所有键的集合
* 遍历键的集合,获取到每一个键
* 根据键找值
*B:案例演示
* Map集合的遍历之键找值
HashMap hm = new HashMap<>();
hm.put("张三", 23);
hm.put("李四", 24);
hm.put("王五", 25);
hm.put("赵六", 26);
/*Set keySet = hm.keySet(); //获取集合中所有的键
Iterator it = keySet.iterator(); //获取迭代器
while(it.hasNext()) { //判断单列集合中是否有元素
String key = it.next(); //获取集合中的每一个元素,其实就是双列集合中的键
Integer value = hm.get(key); //根据键获取值
System.out.println(key + "=" + value); //打印键值对
}*/
for(String key : hm.keySet()) { //增强for循环迭代双列集合第一种方式
System.out.println(key + "=" + hm.get(key));
}