• 单列集合:Collection

    • Set:无序,不可重复

    • List:

      • 有序,可以重复。速度快,因为底层维护的是数组,数组的内存地址是连续的,所以查询的时候快,但是移动的效率低,因为增删的时候需要判断原数组长度是否够用,如果不够,需要将旧的数组拷贝到新的数组中!
      • 适合于查询多余增删的情况
  • 双列集合:Map


1.Set

1.2HashSet

  • HashSet的内部是维护一个Object数组

  • 当每次添加的时候,先调用HashCode获取道哈希值,通过这个值进行位运算,获得在哈希表中位置:

    • 如果没有元素在这个位置,那么直接存储

    • 如果有元素存在这个位置,那么调用equals方法,,返回false才添加

  • 哈希表每个元素位置维护一个哈希桶,所以在同一个哈希表元素位置可以添加多个存储对象

TreeSet

TreeSet内部是一个红黑树,所以TreeSet可以实现自动排序,分为两种情况:

  • 自然元素:自动实现排序,不需要特别调整。但是需要注意的是对字符串的排序

    • 如果找到相同的字符串,那么从不同位置的字符串开始比较

    • 如果找不到相同的字符串,那么以长度来比较

  • 非自然元素:

    • 实现Comparable 接口,并且重写这个接口的Comparable To方法。
package per.liyue.code.treeset;
public class User implements Comparable{
private int id;
private String name;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
} @Override
public String toString() {
// TODO Auto-generated method stub
return "{id:" + this.id + " name:" + this.name + "}";
} @Override
public int compareTo(Object o) {
// TODO Auto-generated method stub
User com = (User)o;
return this.id - com.id;
}
}
package per.liyue.code.treeset;
import java.util.TreeSet;
public class MainPrint {
public static void main(String[] args){
//实现Comparable接口
TreeSet<User> mytreeSet = new TreeSet<>();
User u1 = new User();
u1.setId(3);
u1.setName("z"); User u2 = new User();
u2.setId(1);
u2.setName("f"); User u3 = new User();
u3.setId(2);
u3.setName("b"); mytreeSet.add(u1);
mytreeSet.add(u2);
mytreeSet.add(u3); System.out.println(mytreeSet);
}
}
*实现Comparator 接口实现比较器,并且在创建TreeSet时候传入这个比较器

   比较器格式为:
public class 类名 implements Comparator {
//..... }
package per.liyue.code.treeset;
import java.util.Comparator;
public class MyComparator implements Comparator {
@Override
public int compare(Object o1, Object o2) {
if ((o1 instanceof User) && (o2 instanceof User)) {
User u1 = (User)o1;
User u2 = (User)o2;
return u1.getId() - u2.getId();
}
return 0;
} }
package per.liyue.code.treeset;
import java.util.TreeSet;
public class MainPrint {
public static void main(String[] args){
//实现Comparator接口
MyComparator c = new MyComparator();
//带参构造
TreeSet<User> mytreeSet2 = new TreeSet<>(c);
User u11 = new User();
u11.setId(3);
u11.setName("z"); User u22 = new User();
u22.setId(1);
u22.setName("f"); User u33 = new User();
u33.setId(2);
u33.setName("b"); mytreeSet2.add(u1);
mytreeSet2.add(u2);
mytreeSet2.add(u3); System.out.println(mytreeSet2);
}
}

推荐使用比较器,并且在一个类即实现比较接口又实现比较器的时候,以比较器为准!

比较器和比较接口中如果返回0表示重复,不能添加成功,负整数为小元素,正整数位大元素


2.List

2.1ArrayList

  • 底层维护了一个Object数组

    *它的无参构造创建一个对象时候,其底层维护的Object数组默认10,长度不够时候自动增加0.5倍

2.1.1ArrayList和Vector的区别

  • 二者内部都是维护一个Object数组来实现
  • ArrayList是线程不安全,Vector线程安全。但是后者版本从JDK1.0开始,已经被淘汰。

2.2LinkedList

  • 链表实现

3.Queue


4.各种线性表的性能


5.Map概念


6.各类Map的性能


7.线程安全的集合工具类:Collections



public static void main(String[] args) {
Collection c = Collections.synchronizedCollection(new ArrayList());
List l = Collections.synchronizedList(new ArrayList());
Set s = Collections.synchronizedSet(new HashSet());
Map m = Collections.synchronizedMap(new HashMap());
}

16.Set、List、Queue集合;Map.md的更多相关文章

  1. Java集合的Stack、Queue、Map的遍历

    Java集合的Stack.Queue.Map的遍历   在集合操作中,常常离不开对集合的遍历,对集合遍历一般来说一个foreach就搞定了,但是,对于Stack.Queue.Map类型的遍历,还是有一 ...

  2. HashMap和HashSet的使用,区别。集合,Array、Collection(List/Set/Queue)、Map

    HashMap和HashSet的区别 HashMap和HashSet的区别是Java面试中最常被问到的问题.如果没有涉及到Collection框架以及多线程的面试,可以说是不完整.而Collectio ...

  3. 【由浅入深理解java集合】(五)——集合 Map

    前面已经介绍完了Collection接口下的集合实现类,今天我们来介绍Map接口下的两个重要的集合实现类HashMap,TreeMap.关于Map的一些通用介绍,可以参考第一篇文章.由于Map与Lis ...

  4. 「 深入浅出 」集合Map

    系列文章: 「 深入浅出 」java集合Collection和Map 「 深入浅出 」集合List 「 深入浅出 」集合Set 前面已经介绍完了Collection接口下的集合实现类,今天我们来介绍M ...

  5. 《C#本质论》读书笔记(16)构建自定义集合

    16.1 更多集合接口 集合类(这里指IEnumerable层次结构)实现的接口层次结构 16.1.1 IList<T>与IDictionary<TKey,TValue> 字典 ...

  6. Java——(六)Collection之Queue集合

    ------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- Queue集合 Queue集合用于模拟队列这种数据结构,队列通常是指“先进先出‘(FIFO)的容 ...

  7. (7)Java数据结构--集合map,set,list详解

    MAP,SET,LIST,等JAVA中集合解析(了解) - clam_clam的专栏 - CSDN博---有颜色, http://blog.csdn.net/clam_clam/article/det ...

  8. 14.Java集合简述.md

    Java的集合类别,分为两类Collection和Map,Collenction包含了Set: •Set:无序,不可重复的集合 •List:有序,重复的集合 •Map:具有映射关系的集合 •Queue ...

  9. Java集合—Map

    简介 Map用户保存具有映射关系的数据,因此Map集合里保存着两组数,一组值用户保存Map里的key,另一组值用户保存Map里的value,key和value都可以是任何引用类型的数据.Map的key ...

  10. 20_java之集合Map

    01Map集合概述 A:Map集合概述: 我们通过查看Map接口描述,发现Map接口下的集合与Collection接口下的集合,它们存储数据的形式不同  a:Collection中的集合,元素是孤立 ...

随机推荐

  1. 安装MySQL_Python时出现is not a supported wheel on this platform.

    MySQL-Python 数据库驱动安装 pip install mysql_python失败 不支持windows操作系统 解决: 自行下载安装 下载网站 http://www.lfd.uci.ed ...

  2. WordPress整站轻松开启HTTPS

    近两年来HTTPS取代HTTP已经成为大势所趋.早在2014年google Chromium安全团队提议将所有的HTTP协议网站标注为不安全.现在,Chrome浏览器已经开始执行这一标准了.从 Chr ...

  3. python-day02-购物车

    购物车 需求: 1.启动程序后,让用户输入工资,然后打印商品列表: 2.容许用户根据商品编号购买商品: 3.用户选择商品后,检测余额是否足够,够了就直接扣款,不够就提醒客户: 4.随时可以退出,退出时 ...

  4. mapreduce深入剖析5大视频

    参考代码 TVPlayCount.java package com.dajiangtai.hadoop.tvplay; import java.io.IOException; import org.a ...

  5. 安装配置Glusterfs

    软件下载地址:http://bits.gluster.org/pub/gluster/glusterfs/3.4.2/x86_64/ 192.168.1.11 10.1.1.241 glusterfs ...

  6. day18包的使用与日志(logging)模块

    包的使用与日志(logging)模块1. 什么是包    包就是一个包含有__init__.py文件的文件夹    包本质就是一种模块,即包是用包导入使用的,包内部包含的文件也都是用来被导入使用2 为 ...

  7. MVC Html辅助方法DropDownList的简单使用、连接MYSQL数据库用自定义model类接收

    附上启发链接:https://www.cnblogs.com/CreateMyself/p/5424894.html [HttpGet] public ActionResult Edit(int id ...

  8. Maven依赖下载速度慢,不用怕,这么搞快了飞起

    一.背景 众所周知,Maven对于依赖的管理让我们程序员感觉爽的不要不要的,但是由于这货是国外出的,所以在我们从中央仓库下载依赖的时候,速度如蜗牛一般,让人不能忍,并且这也是大多数程序员都会遇到的问题 ...

  9. 《机器学习实战》ID3算法实现

    注释:之前从未接触过决策树,直接上手对着书看源码,有点难,确实有点难-- 本代码是基于ID3编写,之后的ID4.5和CART等还没学习到 一.决策树的原理 没有看网上原理,直接看源码懂得原理,下面是我 ...

  10. Eclipse中JSP生成的class文件去了哪里?

    转自:http://www.cnblogs.com/xing901022/p/4352999.html 首先应该了解的是Tomcat在Eclipse的映射关系,参考前一篇博文所述:Tomcat的服务器 ...