• jdk顺序表笔记


    一、AbstractCollection

    提供了集合的最大实现
    继承该类,必须实现size()和iterator(),因为该类操作集合都是通过iterator

    二、fail-fast策略

    该策略在集合框架中多次被应用
    一种多线程对同一集合操作的保护措施,确保操作目标没有被其他线程操作过,与cas思想有异曲同工之处
    具体在集合中的实现:
    定义一个全局变量modCount,表示集合被修改的次数
    每次进行动态操作的时候,modCount++
    在Iterator中定义一个全局变量expectedModCount,
    每次操作Iterator的时候都会比较modCount和expectedModCount,相等则认为这个集合没有被并发修改,否则会抛出ConcurrentModificationException
    所以只要有modCount这个变量的,都是线程不安全的,这种集合最好使用迭代器,因为直接操作不会检查集合有没有被并发修改
    使用volatile修饰modCount
    被volatile修饰的变量,程序中的每次引用,处理器都会从内存(共享内存)中去读值,而不是从寄存器(线程独有内存)中获取
    这使得fail-fast策略更可靠

    三、AbstractList

    提供了顺序表的最大实现
    该类实现了迭代器
    继承该类,需要实现get方法,因为迭代器的next是调用了get

    四、ArrayList

    1.初始容量为10

    构造器(集合)和addAll,是深拷贝,因为调的是AbstractCollection.toArray()---->Arrays.copyOf()------>System.arraycopy()

    2.多用会用trimToSize

    因为顺序表一建立的时候,就会创建一个初始大小的数组,这样就会有空余的位置,调用这个方法可以把多余的位置清理,节约空间
    实际长度是存储数组的length,不是全局变量size,size意味着有多个个元素是有数据的

    3.扩展容量

    默认是增大一半的空间,要考虑int溢出(溢出<0),以及虚拟机的最大内存
    必用ensureCapacity(int minSize),需要增大容量的时候,都要调用
    都要确认这个容量是否支持,不支持则会扩展容量
    防止数组越界

    4.toArray,clone都是深度拷贝

    5.维护的数组是没有泛型的,当需要获取元素的时候,才去转型

    6.对于动态操作

    并没有像通常数据结构的书那样子,要移动操作元素后续的节点,而是直接拷贝一份

    7.养成好习惯

    动态操作了之后,不单单只是移动指针,要将不存在的元素位置设置为null,目的是为了让垃圾收集器工作

    8.提供一些安全性低,但是快速的private方法

    比如remove(Obj),获取下标了之后,就可以调用一个fastRemove(index),不需要二次比较值

    9.subList(from,to)

    返回的是该集合的视图,视图是浅拷贝,会直接操作该集合
     
    a192136220-94766

    查看原文:http://blog.zswlib.com/2016/10/26/jdk%e9%a1%ba%e5%ba%8f%e8%a1%a8%e7%ac%94%e8%ae%b0/

  • 相关阅读:
    (转)多线程同步event
    初始化列表中成员列出的顺序和它们在类中声明的顺序相同
    确定基类有虚析构函数
    (转)list::splice()函数详解
    MANIFEST.MF文件的格式
    NIO入门了解Buffer
    Failed to load class "org.slf4j.impl.StaticLoggerB
    线程挂起自己,让出CPU
    database如何管理超过4GB的文件
    线程同步(C# 编程指南)
  • 原文地址:https://www.cnblogs.com/wewill/p/6001567.html
Copyright © 2020-2023  润新知