Jared's blog Jared's blog
首页
  • 数据结构与算法
  • 计算机网络
  • 操作系统
  • Java
  • 数据库SQL
  • 设计模式
  • 集成开发环境
  • Linux系统
  • 代码管理
  • 项目管理
  • 后端

    • 中间件
    • Spring家族
    • 服务器软件
    • 数据库
    • 搜索引擎
    • 分布式&微服务
    • 容器化
  • 前端

    • 基础
    • 模板框架
    • 组件化框架
  • 运维知识
  • 部署工具
架构与模型
  • 在线教育
  • 电商
  • 疑惑日志
  • 随笔
  • 友链
  • 书籍
  • 娱乐
  • Github (opens new window)
  • Gitee (opens new window)
  • CSDN (opens new window)

Jared H

💻🤣😜
首页
  • 数据结构与算法
  • 计算机网络
  • 操作系统
  • Java
  • 数据库SQL
  • 设计模式
  • 集成开发环境
  • Linux系统
  • 代码管理
  • 项目管理
  • 后端

    • 中间件
    • Spring家族
    • 服务器软件
    • 数据库
    • 搜索引擎
    • 分布式&微服务
    • 容器化
  • 前端

    • 基础
    • 模板框架
    • 组件化框架
  • 运维知识
  • 部署工具
架构与模型
  • 在线教育
  • 电商
  • 疑惑日志
  • 随笔
  • 友链
  • 书籍
  • 娱乐
  • Github (opens new window)
  • Gitee (opens new window)
  • CSDN (opens new window)
  • 数据结构与算法

  • 计算机网络

  • 操作系统

  • Java

    • 语言基础

    • 集合

      • 集合
        • 集合类存放于Java.util包中,主要有3种
        • List、Set
        • Map
        • 遍历集合的几种方式
    • 并发、多线程

    • JVM

    • 工具

    • IO

    • 新特性

    • http通信流程图
  • 数据库-SQL

  • 设计模式

集合

# 2.集合

  • 集合类存放于Java.util包中,主要有3种
  • List、Set
  • Map
  • 遍历集合的几种方式

参考:https://www.bilibili.com/video/BV1mE411x7Wt/index_218.html

# 集合类存放于Java.util包中,主要有3种

set(集)、list(列表)、map(映射)

# List、Set

  • ArrayList:底层是数组。

  • LinkedList:底层是双向链表。

  • Vector:底层是数组,线程安全的,线程同步的,某一时刻只有一个线程能够写 Vector,所有效率较低,使用较少。

  • HashSet:底层是HashMap,放到HashSet集合中的元素等同于放到HashMap集合key部分了。

  • TreeSet:底层是TreeMap,放到TreeSet集合中的元素等同于放到TreeMap集合key部分了。

注:自定义的类必须实现 Comparable 接口,并且重写相应的 compareTo()方法,方法内部定义排序规则 ,才可以正常使用TreeSet。 TreeSet的add方法底层调用TreeMap的put方法:

List 集合使用Collections.sort()方法进行排序。

public class Student implements Comparable<Student>{
    String name;
    int age;
    float score;
//省略set get toString...

    //k.compareTo(t.key)
    //参数k是拿来与集合中每一个t.key来比较的
    //如果升序 k(this)-t.key,反之。

    @Override
    public int compareTo(Student o) {//s1.compareTo(s2);
        if (this.score == o.score){
            return this.age-o.age;//年龄升序
        }else return (int) (o.score-this.score);//成绩降序
    }

    //使用内部类创建比较器
    static class StudentComparetor implements Comparator<Student> {
    @Override
    public int compare(Student o1, Student o2) {
        if (o2.score == o1.score){
            return o1.age-o2.age;
        }return (int) (o2.score-o1.score);
    }
   }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
public class test {
    public static void main(String[] args) {
        Student liusan=new Student("liusan",20,90.0F);
        Student lisi=new Student("lisi",22,90.0F);
        Student wangwu=new Student("wangwu",20,99.0F);
        Student sunliu=new Student("sunliu",22,100.0F);

        List<Student> l=new ArrayList();

        l.add(liusan);
        l.add(wangwu);
        l.add(lisi);
        l.add(sunliu);
        Collections.sort(l);
        //内部类创建一个比较器类,排序时new一个比较器对象
//        Collections.sort(l,new Student.StudentComparetor());
        for (Student s:l
             ) {
            System.out.println(s);
        }

    }

}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24

# Map

  • HashMap:底层是哈希表。

    HashMap 是一种基于扰动函数、负载因子、红黑树转换等技术内容,形成的拉链寻址的数据结构,它能让数据更加散列的分布在哈希桶以及碰撞时形成的链表和红黑树上。它的数据结构会尽可能最大限度的让整个数据读取的复杂度在 O(1) ~ O(Logn) ~O(n)之间,当然在极端情况下也会有 O(n) 链表查找数据较多的情况。经过10万数据的扰动函数再寻址验证测试,数据会均匀的散列在各个哈希桶索引上,所以 HashMap 非常适合用在 Spring Bean 的容器实现上。

  • Hashtable:底层也是哈希表,只不过线程安全的,效率较低,使用较少。

  • Properties:是线程安全的,并且key和value只能存储字符串String。

  • TreeMap:底层是二叉树。TreeMap集合的key可以自动按照大小顺序排序。

ConcurrentHashMap

  • Segment段:

    整个 ConcurrentHashMap 由一个个 Segment 组成,Segment 代表”部分“或”一段“的意思,所以很多地方都会将其描述为分段锁。

  • 线程安全(Segment 继承 ReentrantLock 加锁)

    简单理解就是,ConcurrentHashMap 是一个 Segment 数组,Segment 通过继承ReentrantLock 来进行加锁,所以每次需要加锁的操作锁住的是一个segment,这样只要保证每个 Segment 是线程安全的,也就实现了全局的线程安全。

  • 并行度(默认 16)

    concurrencyLevel:并行级别、并发数、Segment 数。ConcurrentHashMap 默认有 16 个 Segments,所以理论上,这个时候,最多可以同时支持 16 个线程并发写,只要它们的操作分别分布在不同的 Segment 上。这个值可以在初始化的时候设置为其他值,但是一旦初始化以后,它是不可以扩容的。再具体到每个Segment 内部,其实每个 Segment 很像之前介绍的 HashMap,不过它要保证线程安全,所以处理起来要麻烦些。

# 遍历集合的几种方式

1.使用foreach 2.迭代器Iterator

Iterator<String> it=list.iterator();
        while (it.hasNext()){
            System.out.println(it.next());
        }
1
2
3
4

3.通过map的keySet()获得key的set集合再迭代通过map.get(key)获得value 4.使用Map的静态内部类Entry

public class MapTest01 {
    public static void main(String[] args) {
        Map<Integer,String> map = new HashMap<Integer, String>();
        map.put(1, "张三丰");
        map.put(2, "周芷若");
        map.put(3, "汪峰");
        map.put(4, "灭绝师太");

        Set<Map.Entry<Integer,String>> node=map.entrySet();
        for (Map.Entry<Integer,String> data:node
             ) {
            System.out.println(data);//得到 key=value
            System.out.println(data.getKey()+"---->"+data.getValue());
        }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
上次更新: 2022/04/01, 15:14:40
复制
理论基础

← 复制 理论基础→

Theme by Vdoing Copyright © 2020-2022 Jared H
粤ICP备20046800号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式
×