【Java编程思想笔记】-集合2
详细的接口API转自博客:https://blog.csdn.net/jyg0723/article/details/80498840#collection-api-%E8%AF%A6%E8%A7%A3
集合详解转自博客:https://www.cnblogs.com/ysocean/p/6555373.html
三大接口:Iterator , Collection , Map
1.Collection接口:
Collection是 Set、 List、 Queue和 Deque(Queue: 先进先出队列 Deque: 双向链表)的接口。
基本方法:
boolean add(E e) 添加新元素,但不能添加集合中已有的元素 ,这是考虑到Set中不能有重复的元素。
boolean addAll(Collection<? extends E> c) , 添加某一集合的所有元素到该集合中。 (如果添加的集合中有和本集合重复的元素怎么办?)
boolean contains(Object o) 如果集合中包含指定元素那么返回true。特别的,如果集合中也包含NULL元素的时候并且要查找的元素也是NULL的时候也返回true。
boolean containsAll() , boolean isEmpty() , void clear() 等等
1.1 List接口
List接口在Collection的基础上添加了一些方法,重写了一些列函数,使得可以在List的中间插入和移除元素。
和Set集合不同的地方是:有序,允许重复元素
List的常见实现类:
(1)ArrayList:
List<E> alist = new ArrayList<>();
底层数据结构是数组,查询快,增删慢;线程不安全,效率高
它善于随机访问元素,但是在List的中间插入和移除元素时较慢。
(2)LinkedList:
List<E> llist = new LinkedList<>();
底层数据结构是链表,查询慢,增删快;线程不安全,效率高
它通过代价较低地在List中间进行插入和删除工作,提供了优化的顺序访问。LinkedList在随机访问方面相对比较慢,但是它的特性集较ArrayList更大。
(3)Vector:
List<E> vlist = new Vector<>();
底层数据结构是数组,查询快,增删慢;线程安全,效率低,几乎已经淘汰了这个集合
1.2 Set接口
Set与List不同点:无序(不是普通意义上的无序,具体可以看顶部的博客),不允许重复元素
Set不保存重复的元素,Set中最常被使用的是测试归属性,你可以很容易地询问某个对象是否在某个Set中。正因为如此,查找成为了Set中最重要的操作,因此通常会选择一个HashSet的实现,它专门对快速查找进行了优化。
Set具有与Collection完全一样的接口,因此没有额外功能。实际上Set就是Collection,只是行为不同(继承与多态的表现)。
Set的实现类:
(1)HashSet:底层数据结构是哈希表(是一个元素为链表的数组) 。
它是Set的典型实现,不能保证元素的顺序,不可重复,不是线程安全的,集合元素可以为NULL
(2)TreeSet:底层数据结构是红黑树(是一个自平衡的二叉树)。保证元素的排序方式 ,不可重复,善于范围查询
(3) LinkedHashSet:底层数据结构由哈希表和链表组成。不可以重复,有序
因为底层采用 链表 和 哈希表的算法。链表保证元素的添加顺序,哈希表保证元素的唯一性
public void setrun(){
//HashSet中的数据不按添加顺序存储
HashSet<Integer> hset =new HashSet<>();
hset.add(88);
hset.add(8);
hset.add(888); System.out.println(hset); //LinkedHashSet中的数据按照添加顺序存储
LinkedHashSet<Integer> lhset = new LinkedHashSet<>();
lhset.add(88);
lhset.add(8);
lhset.add(888); System.out.println(lhset); //TreeSet中的数据会进行排序
TreeSet<Integer> tset = new TreeSet<>();
tset.add(88);
tset.add(8);
tset.add(888); System.out.println(tset);
}
2.Map:key-value 的键值对,key 不允许重复,value 可以
1、严格来说 Map 并不是一个集合,而是两个集合之间 的映射关系。
2、我们可以把两个集合之间成映射关系的一对数据,看成是一条数据。即 Entry(key,value)。Map 可以看成是由多个 Entry 组成。
3、因为 Map 集合即没有实现 Collection 接口,也没有实现 Iterable 接口,所以不能对 Map 集合进行 for-each 遍历
4、Map的通用实现类有:HashMap,HashTable,LinkedHashMap,TreeMap,WeakHashMap等等(这里主要实现HashMap)
public void HashMaprun(){
HashMap<Integer,String> hmap = new HashMap<>(); //添加元素到HashMap中
for (int i = 0; i < 10; i++) {
hmap.put(i,"String"+i);
}
System.out.println(hmap); //通过key值删除元素
String str = hmap.remove(3);
System.out.println(str); //通过key值获取元素
str = hmap.get(5);
System.out.println(str); //通过添加已有的key来修改该key中的value
hmap.put(2,"测试2");
str = hmap.get(2);
System.out.println(str); //通过keySet()方法得到key的集合,然后遍历keySet来遍历Value的集合
Set<Integer> keyset = hmap.keySet();
for(Integer i:keyset){
String temp = hmap.get(i);
System.out.print(temp+" -- ");
} System.out.println(""); //通过entrySet()得到Map的Entry集合,然后遍历
Set<Map.Entry<Integer,String>> entries = hmap.entrySet();
for(Map.Entry<Integer,String> entry:entries){
Integer key = entry.getKey();
String value = entry.getValue();
System.out.println(key+"<===>"+value);
}
}
2.1 HashMap: 采用哈希表算法,此时Map中的key不会保证添加的先后顺序,key也不允许重复
key判断重复的标准是:key1和key2是否equals为true,并且hashCode相等
2.2 TreeMap:采用红黑树算法,此时Map中的key会按照自然顺序或定制顺序进行排序,key也不允许重复
key判断重复的标准是:compareTo/compare的返回值是否为0
2.3 LinkedHashMap:采用链表和哈希表算法,此时Map中的Key会保证先后添加的顺序,key不允许重复
key判断重复的标准和HashMap相同
2.4HashTable: 采用哈希表算法,是HashMap的前身
在java的集合框架之前,表示映射关系就用HashTable
所有的方法都是用synchronized修饰符,线程安全,但是性能比HashMap第
2.5 Properties: Hashtable的子类,此时要求key和value都是String类型
用来加载资源文件(I/O)
注意:Map和Set集合有很大程度上的相似,都有使用哈希表和红黑树实现的子类
实际上,Set集合就是由Map集合的key组成的。
【Java编程思想笔记】-集合2的更多相关文章
- java编程思想笔记(1)
java编程思想笔记(1) 一,对象的创建和生命周期 对象的数据位于何处?怎样控制对象的生命周期? 在堆(heap)的内存池中动态地创建对象. java完全采用了动态内存分配方式. 二,垃圾回收器 自 ...
- Java编程思想 笔记
date: 2019-09-06 15:10:00 updated: 2019-09-24 08:30:00 Java编程思想 笔记 1. 四类访问权限修饰词 \ 类内部 本包 子类 其他包 publ ...
- #Java编程思想笔记(一)——static
Java编程思想笔记(一)--static 看<Java编程思想>已经有一段时间了,一直以来都把笔记做在印象笔记上,今天开始写博客来记录. 第一篇笔记来写static关键字. static ...
- 2.1(java编程思想笔记)位移操作
java位移操作主要有两种: 有符号位移:有符号位移会保留原有数字正负性,即正数依然是正数,负数依然是负数. 有符号位左移时,低位补0. 有符号右移时:当数字为正数,高位补0.当数字为负时高位补1. ...
- 【Java编程思想笔记】-集合1
1.为什么要用集合? 一般情况下,数组是保存一组对象(或基本数据类型)最有效的方式.但是数组有着固定的尺寸,而在更一般的情况下,我们在写程序时不知道将需要保存多少个对象,或者是否需要更复杂的存储结构来 ...
- java编程思想笔记(第一章)
Alan Kay 第一个定义了面向对象的语言 1.万物皆对象 2.程序是对象的集合,他们彼此通过发送消息来调用对方. 3.每个对象都拥有由其他对象所构成的存储 4.每个对象都拥有其类型(TYpe) 5 ...
- java编程思想笔记(一)——面向对象导论
1.1 抽象过程 1.所有编程语言都提供抽象编程机制. 2.人们所能够解决的问题的复杂性直接取决于抽象的类型(所抽象的是什么)和质量. 3."命令式"语言(basic,c等)都是对 ...
- 7.JAVA编程思想笔记隐藏实施过程
欢迎转载,转载请标明出处:http://blog.csdn.net/notbaron/article/details/51040237 "进行面向对象的设计时,一项主要的考虑是:怎样将发生变 ...
- 【Java编程思想笔记】注解1-简单了解注解
文章参考:https://www.cnblogs.com/xuningchuanblogs/p/7763225.html https://www.cnblogs.com/xdp-gacl/p/3622 ...
随机推荐
- 如何重置mysql中的root密码
方法一: 在my.ini的[mysqld]字段加入:skip-grant-tables重启mysql服务,这时的mysql不需要密码即可登录数据库 然后进入mysqlmysql>use mysq ...
- 被顶级学术期刊枪毙的p.Value到底是个什么鬼
总结一下,在我看来,p.Value仅仅是在,假设检验,这理论框架下,对于证据力度的一个测量.而且,我们不大可能推翻假设检验这个框架,似乎也不必要,因为,这个框架非常合理,有广泛的应用场景,有强大的生命 ...
- 全局拦截各种http请求
http请求无非就是ajax.src.href.表单 function hookAJAX() { XMLHttpRequest.prototype.nativeOpen = XMLHttpReques ...
- 体验Hadoop3.0生态圈-CDH6.1时代的来临
体验Hadoop3.0生态圈-CDH6.1时代的来临 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 我在公司使用的是CDH5.15.1这个发行版本,具体的部署文档之前也有给大家分享 ...
- Hbase运维手册(1)
1. region情况 需要检查 1. region的数量(总数和每台regionserver上的region数) 2. region的大小 如果发现异常可以通过手动merge region和手动分配 ...
- 【JS】js将 /Date(1518943415760+0800)/ 转换为2018-2-18 16:43:35格式
function formatDate(dt) { var year = dt.getFullYear(); var month = dt.getMonth() + 1; var date = dt. ...
- R语言学习网址
1. https://www.r-bloggers.com/ 2. https://www.kaggle.com/datasets 3. RStudio download: https://www.r ...
- python django基础四 ORM简介
ORM,全称是object relation mapping.翻译过来,就是对象关系映射. 主要来学习MySQL操作,MySQL是一个软件.它的优点:1.免费 2.开源 pymysql,就是Mysql ...
- go结构体方法
Golang中的方法是作用在特定类型的变量上,因此自定义类型,都可以有方法,而不仅仅是struct. 定义格式 func (var *Struct_Name) FuncName( var0, var1 ...
- vue中nextTick
vue中nextTick可以拿到更新后的DOM元素 如果在mounted下不能准确拿到DOM元素,可以使用nextTick 在Vue生命周期的created()钩子函数进行的DOM操作一定要放在Vue ...