集合

作者: 闫子扬 | 来源:发表于2017-05-03 20:10 被阅读0次

###集合,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));

}

相关文章

  • 我的Swift的学习总结 -->第二周

    集合 集合:Set,定义一个集合可以写成:var 集合名 : Set<集合类型> = [集合元素],具体的集合应用...

  • markdown 测试

    集合 集合 集合 引用

  • kotlin学习第五天:集合,高阶函数,Lambda表达式

    集合 list集合 list集合分为可变集合与不可变集合。由list of创建的集合为不可变集合,不能扩容,不能修...

  • kotlin练习 ---- 集合练习

    kotlin练习 - 集合练习 Set集合 Set集合创建 Set集合的使用 List集合 List集合创建 Li...

  • 集合总结

    集合 集合分为单列集合和双列集合两种: 一.单列集合: Collection是单列集合的顶级接口: 其中有三类集合...

  • 映射、元组、集合

    映射 元组 集合 集合之seq 集合之set 集合之map

  • 16.Collection集合

    主要内容: Collection 集合 迭代器 增强for List 集合 Set 集合 1,集合 集合是java...

  • 集合与有序集合

    集合分为有序集合 (zset) 和无序集合 (set), 一般无序集合也直接说成集合 无序集合 (set) 无序集...

  • python入坑第八天|集合

    好的,各位蛇友,我们今天来学习集合。 内容: 集合的创建 集合操作符号 集合的内置函数 集合的创建 集合用set(...

  • 集合框架

    集合框架的概念 集合:存放数据的容器 集合框架:java中,用于表示集合,以及操作集合的类和接口的统称 数组与集合...

网友评论

      本文标题:集合

      本文链接:https://www.haomeiwen.com/subject/yneltxtx.html