一、构造方法
1 2 3 4 | Vector():构造一个空向量,使其内部数据数组的大小为 10 ,其标准容量增量为零。 Vector( int initialCapacity) :使用指定的初始容量和等于零的容量增量构造一个空向量 Vector( int initialCapacity, int capacityIncrement):使用指定的初始容量和容量增量构造一个空的向量 Vector(Collection<? extends E> c) :构造一个包含指定 collection 中的元素的向量,这些元素按其 collection 的迭代器返回元素的顺序排列。 |
源码跟踪:
1、先看无参的构造方法:
2、有一个 int 参数的构造方法
3、有两个 int参数的构造方法
总结:
从上面的三个方法中可以看出,如果调用无参的构造方法,默认初始化的长度为10的数组,默认增量为0。
当使用一个参数时,可以为其指定初始化容量。
当使用两个参数的方法时,不仅仅可以指定初始化容量,还可以指定增量。
二、常用方法
1、add(E e) 方法
源码跟踪(JDK1.8):
源码跟踪(JDK1.9):
总结:
当调用 add(E e) 方法时,会调用第二张图的 add 方法,其中会检验长度是否够,如果不够,会调用图三的 grow 方法,grow 方法中调用了图四的 newCapacity 扩容方法,如果你手动指定了capacityIncrement的值,那么可以按照你指定增量进行扩容。如果没有默认值为0,会扩容为原来的2倍。
2、add(int index,Object e)方法
源码跟踪(JDK1.8):
源码跟踪(JDK1.9):
总结:
可以看出,当调用add(index,Object) 方法后,实际上是调用的 insert 方法,首先进行了index的校验,然后是数组长度的校验,然后进行数据的插入。
3、remove(int index) 方法
源码跟踪(JDK1.8):
总结:根据索引删除一个元素,会先进行索引的校验,然后判断需要挪动的元素的个数;如果为0个,不需要执行操作,节省时间,如果不为0,再移动数组。
4、remove(Object) 方法
源码跟踪(JDK1.8):
总结:
当根据一个元素值删除时,会先去查找该值所在的索引,如果能够找到,在根据索引进行删除。
5、indexOf(Object obj) 与 indexOf(Object obj, int index) 方法
源码跟踪(JDK1.8):
总结:
查询元素位置时,对元素进行分情况讨论,① 是null;② 不是 null。然后进行查找,第二个参数为指定开始查找的索引,如果不指定,默认从0开始查找。
6、set(int index, Object obj) 方法
源码跟踪(JDK1.8):
总结:
根据索引赋值时,首先进行索引的校验,然后把新值填充到指定索引的位置。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 没有源码,如何修改代码逻辑?
· NetPad:一个.NET开源、跨平台的C#编辑器