学习
实践
活动
专区
工具
TVP
写文章

Java容器 ArrayList

ArrayList到底能不能被序列化呢? 这里先说结论 ArrayList 是能被序列化的,有兴趣的同学可以做个实验,后面在回顾基础的时候会专门对序列化进行分析。 扩容 ArrayList 有三个构造函数 ArrayList(int initialCapacity) //指明容器大小 ArrayList() // 默认容器初始化大小 ArrayList(Collection 有很多资料说ArrayList 构造函数如果不指定大小,默认是10,这种说法是不严谨的。默认初始化后的大小其实是0,第一次扩容大小为10。 的操作都会修改modCount,如果在迭代的过程中ArrayList被修改就会触发快速失败。 使用规范 阿里的Java操作手册中有如下几点强制规范(这里引用一下): 【强制】ArrayList的subList结果不可强转成ArrayList

40400
  • 广告
    关闭

    【玩转 GPU】有奖征文

    精美礼品等你拿!

  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Java ArrayList和LinkedList

    目录 集合的概念 集合体系结构 常用list集合 list集合的特点 ArrayList LinkedList 创建对象 常用方法 遍历 ArrayList和LinkedList的区别 集合的概念 ​ Java中提供了使用不同数据结构存储数据的不同集合类,他们有各自不同的特点,并且在类中提供了很多常用了方法,便于我们使用。 集合体系结构 ​ 集合主要有两个顶层接口,Collection和Map。 集合体系图 常用list集合 list集合的特点 ​ List接口下的集合都会有以下特点: 有索引 可以存储重复元素 元素存入的顺序和实际存储的顺序相同 ArrayList 创建对象 ArrayList list = new ArrayList<>();//不限定集合中存放元素的数据类型 ArrayList<集合元素的数据类型> list2 = new ArrayList<>();//限定集合中存放元素的数据类型 3.使用foreach遍历 ​ foreach是java提供的一个语法。可以让我们更方便的遍历集合或数组。

    14510

    Java ArrayList源码剖析

    ArrayList实现了List接口,是顺序容器,即元素存放的数据与放进去的顺序相同,允许放入null元素,底层通过数组实现。除该类未实现同步外,其余跟Vector大致相同。 前面已经提过,Java泛型只是编译器提供的语法糖,所以这里的数组是一个Object数组,以便能够容纳任何类型的对象。 为追求效率,ArrayList没有实现同步(synchronized),如果需要多个线程并发访问,用户可以手动同步,也可使用Vector替代。 方法剖析 set() 既然底层是一个数组ArrayList的set()方法也就变得非常简单,直接对数组的指定位置赋值即可。 hugeCapacity(minCapacity); elementData = Arrays.copyOf(elementData, newCapacity);//扩展空间并复制 } 由于Java

    18040

    Java集合之ArrayList

    ArrayList ArrayList是最常见以及每个Java开发者最熟悉的集合类了,顾名思义,ArrayList就是一个以数组形式实现的集合,以一张表格来看一下ArrayList里面有哪些基本的元素: transient为java关键字,为变量修饰符,如果用transient声明一个实例变量,当对象存储时,它的值不需要维持。Java的serialization提供了一种持久化对象实例的机制。 结论 ArrayList是否允许空 允许 ArrayList是否允许重复数据 允许 ArrayList是否有序 有序 ArrayList是否线程安全 非线程安全 构造函数 ArrayList ArrayList的优缺点 从上面的几个过程总结一下ArrayList的优缺点。 ArrayList和Vector的区别 ArrayList是线程非安全的,这很明显,因为ArrayList中所有的方法都不是同步的,在并发下一定会出现线程安全问题。

    25430

    Java集合:ArrayList详解

    概述 ArrayList是我们日常中最长用的集合之一,在使用列表时,除非特殊情况,我们一般都会选择使用ArrayList,本文就ArrayList的几个主要方法主要介绍,并结合几个图片来介绍几个重要操作 set方法 public E set(int index, E element) { // 用指定的元素(element)替换指定位置(index)的元素 rangeCheck(index oldValue = elementData(index); // 根据index获取指定位置的元素 elementData[index] = element; // 用传入的element替换 index位置的元素 return oldValue; // 返回index位置原来的元素 } 校验索引是否越界 根据index获取指定位置的元素 用传入的element替换index位置的元素 ArrayList和LinkedList比较 LinkedList详解可以看我的另一篇文章:Java集合:LinkedList详解 ArrayList底层基于动态数组实现,LinkedList底层基于链表实现

    23220

    Java源码系列1——ArrayList

    本文简单介绍了 ArrayList,并对扩容,添加,删除操作的源代码做分析。能力有限,欢迎指正。 ArrayList是什么? ArrayList 就是数组列表,主要用来装载数据。 正常使用场景中,ArrayList 都是用来查询,不会涉及太频繁的增删,如果涉及频繁的增删,可以使用 LinkedList。如果需要线程安全就使用 Vector。 如果不够就需要扩容 尾部新增比较快,如果是在数组头部或者中部新增就会慢很多,因为要把后面的元素全部往后移一位 把元素往后移一位使用的是复制 System.arraycopy(),它是native方法(java new ArrayList<>(18) 会不会初始化数组大小? 不会初始化数组大小!!! 这是Java Bug。 public static void main(String[] args) { ArrayList<Integer> a = new ArrayList<>(12); System.out.println

    23930

    扫码关注腾讯云开发者

    领取腾讯云代金券