胖胖的枫叶
主页
展示
博客
产品设计
企业架构
全栈开发
效率工具
数据分析
项目管理
方法论
面试
  • openJdk-docs
  • spring-projects-docs
  • mysql-docs
  • redis-commands
  • redis-projects
  • apache-rocketmq
  • docker-docs
  • mybatis-docs
  • netty-docs
  • journaldev
  • geeksforgeeks
  • 后端进阶
  • 并发编程网
  • 英语肌肉记忆锻炼软件
  • 墨菲安全
  • Redisson-docs
  • jmh-Visual
  • 美团技术
  • MavenSearch
主页
展示
博客
产品设计
企业架构
全栈开发
效率工具
数据分析
项目管理
方法论
面试
  • openJdk-docs
  • spring-projects-docs
  • mysql-docs
  • redis-commands
  • redis-projects
  • apache-rocketmq
  • docker-docs
  • mybatis-docs
  • netty-docs
  • journaldev
  • geeksforgeeks
  • 后端进阶
  • 并发编程网
  • 英语肌肉记忆锻炼软件
  • 墨菲安全
  • Redisson-docs
  • jmh-Visual
  • 美团技术
  • MavenSearch
  • 标签索引
  • 2024年

    • 勇闯大A,宏观美债与美元周期
    • 勇闯大A,自我管理
    • 勇闯大A,交易系统
    • 勇闯大A,买入卖出
    • 勇闯大A,债券市场
    • 勇闯大A,微观&宏观与周期
    • 配置Mac环境
    • 勇闯大A,内外盘&换手率
    • 业务知识会计管理
    • 业务知识会计基础
    • 业务知识什么是财务
  • 2023年

    • 泰国投资项目BOI
  • 2022年

    • 企业架构故障管理
    • 企业架构开发债务
  • 2021年

    • Python3.8 Matplotlib员工数据分析
    • Python3.8 Matplotlib IP折线图
    • Python3.8 词云 IP地址
    • Redis RediSearch
    • Rust第一个CLI程序
    • Rust所有权
    • Rust函数与控制流
    • Rust变量与数据类型
    • Rust入门
    • 企业架构分布式系统
    • 编程式权限设计
    • Java JVM优化
    • SpringBoot MyBatis 批量
    • SpringBoot 测试Mock
    • SpringBoot Redis布隆过滤器
    • CentOS7 Jenkins 部署
    • SpringBoot WebClient
    • Docker Drone 部署
    • SpringBoot MyBatis
    • SpringBoot Redisson
    • SpringBoot MyBatis 雪花算法
    • Java Netty
    • Redis 扫描
    • CentOS7 Jenkins本地部署分级
    • Mac 安装 Neo4j Jupyter
    • Mac OpenJDK11 JavaFX 环境
    • Mac 安装 Jenv
    • SpringBoot Redis 延时队列
    • SpringBoot MDC日志
    • SpringBoot 定时任务
    • CentOS7 Nginx GoAccess
    • SpringBoot MyBatis 分析
    • SpringBoot Lucene
    • 企业架构分布式锁
    • 学习技巧减少学习排斥心理
    • SpringBoot 动态数据源
    • Docker Compose SpringBoot MySQL Redis
    • SpringBoot 阻塞队列
    • Docker Compose Redis 哨兵
    • Docker Compose Redis 主从
    • 网络通信
  • 2020年

    • SpringBoot 延时队列
    • MySQL基础(四)
    • Java 雪花算法
    • Redis Geo
    • 网络通信 Tcpdump
    • Spring SPI
    • Java Zookeeper
    • SpringBoot JMH
    • 网络通信 Wireshark
    • Docker Compose Redis MySQL
    • CentOS7 Docker 部署
    • Netty 源码环境搭建
    • MySQL基础(三)
    • CentOS7 Selenium运行环境
    • CentOS7 Nginx HTTPS
    • Java JMH
    • SpringBoot 修改Tomcat版本
    • Java Eureka 钉钉通知
    • SpringBoot 错误钉钉通知
    • Java JVM
    • Git 合并提交
    • CentOS7 OpenResty 部署
  • 2019年

    • Redis CLI
    • CentOS7 Nginx 日志
    • 编程式代码风格
    • IDEA 插件
    • Skywalking 源码环境搭建
    • SpringBoot Redis 超时错误
    • 编程式 gRPC
    • Java Arthas
    • Docker Compose Redis 缓存击穿
    • Docker ElasticSearch5.6.8 部署
    • Docker Mysql5.7 部署
    • Spring Redis 字符串
    • Docker Zookeeper 部署
    • Docker Redis 部署
    • SpringBoot Dubbo
    • CentOS7 CMake 部署
    • 应用程序性能指标
    • Java Code 递归
    • CentOS7 ELK 部署
    • CentOS7 Sonarqube 部署
    • Java Selenium
    • Java JJWT JUnit4
    • Spring 源码环境搭建
    • Java JUnit4
    • Java Web JSON Token
    • 编程式 FastDFS
    • Java XPath
    • Redis基础(二)
    • Redis基础(一)
    • Java MyBatis JUnit4
    • Java MyBatis H2 JUnit4
    • MyBatis 源码环境搭建
    • Git 配置
    • Java 核心
    • Java Dubbo
    • Java JavaCollecionsFramework
    • Java Maven
    • Java MyBatis
    • Java Spring
    • Java SpringMVC
    • MySQL
    • Redis
  • 2018年

    • Java HashMap
    • Java HashSet
    • Java Code 交换值
    • Spring Upgrade SpringBoot
    • Mac 编程环境
    • Java Log4j
    • 网络通信 Modbus
    • MySQL基础(二)
    • MySQL基础(一)
    • Java Stack
    • Java Vector
    • CentOS7 RabbitMQ 部署
    • CentOS7 Redis 部署
    • CentOS7 MongoDB 部署
    • CentOS7 基础命令
    • Java Eureka Zookeeper
    • CentOS7 MySQL 部署
    • Git 分支
    • CentOS7 Java环境配置
    • Java LinkedList
    • Java ArrayList
    • Spring Annotation Aop

Java Vector

本章是整理知识内容,为强化知识长期更新。

Vector

概述

  • Vector是Java Collection Franmework成员。
  • 列队允许添加重复元素
  • 列队允许null的存在
  • 列队从0开始,也就是列队头部的下标是0。
  • 列队支持泛型,这样可以避免ClassCastException异常。

与ArrayList的区别

  • Vector和ArrayList几乎完全项目,几个不相同的特征分别是。
    • Vector是同步的,自带的方法大多被synchronized修饰。所以开销比ArrayList大很多。
    • Vector默认每次扩容大小,ArrayList 是1.5倍;Vector是2倍。
    • 可以指定扩容系数,不指定就是2倍。
  • 相对与ArrayList,Vector牺牲了性能换取同步,但是实际上可以通过Collections.synchronizedList(new ArrayList<>());来返回一个线程安全的List,可以可以使用concurrent包下CopyOnWriteArrayList类。
  • 所以一般不建议使用Vector。

源码分析下Vector

Vector中常量以及变量

// 集合中的数组元素
protected Object[] elementData;

// 集合中数组大小,这里不是用size。
protected int elementCount;

// 扩容的时候增长数量,如果是0或者负数就是2倍。
protected int capacityIncrement;

// 容器的最大容量
private static final int MAX_ARRAY_SIZE = Integer.MAX_VALUE - 8;

1、如何创建Vector

@Test
public void test() {
    String[] arr = new String[]{"a" , "b" , "c" , "d"};
        Vector list = new Vector(1 , 10);
        list.addAll(Arrays.asList(arr));
        System.out.println(list);

        Vector list1 = new Vector(10);
        list1.addAll(Arrays.asList(arr));
        System.out.println(list1);

        Vector list2 = new Vector();
        list2.addAll(Arrays.asList(arr));
        System.out.println(list2);

        Vector list3 = new Vector(Arrays.asList(arr));

        System.out.println(list3);
}

输出

[a, b, c, d]
[a, b, c, d]
[a, b, c, d]
[a, b, c, d]

这里分别使用了Vectro四个构造方法。

//list
public Vector(int initialCapacity, int capacityIncrement) {
        super();
        //指定容器初始化大小和扩容系数。
        if (initialCapacity < 0)
            throw new IllegalArgumentException("Illegal Capacity: "+
                                               initialCapacity);
        this.elementData = new Object[initialCapacity];
        this.capacityIncrement = capacityIncrement;
}
//list1    
public Vector(int initialCapacity) {
        //指定容器的初始化大小。默认扩容系数0。
        this(initialCapacity, 0);
}    
//list2    
public Vector() {
    // 指定容器的初始化大小为10。
        this(10);
}
//list2
public Vector(Collection<? extends E> c) {
       //将一个Collection容器的元素都复制进来
        elementData = c.toArray();
        elementCount = elementData.length;
        // c.toArray might (incorrectly) not return Object[] (see 6260652)
        if (elementData.getClass() != Object[].class)
            elementData = Arrays.copyOf(elementData, elementCount, Object[].class);
 }

1、看下扩容代码

由于Vector的方法和ArrayList的方法太多相似,这里看看如何扩容的。

// 从add方法入口看
public synchronized boolean add(E e) {
        modCount++;
        ensureCapacityHelper(elementCount + 1);  //判断扩容
        elementData[elementCount++] = e;
        return true;
    
}

private void ensureCapacityHelper(int minCapacity) {
        // overflow-conscious code
        // 如果最小容量不够用了就扩容
        if (minCapacity - elementData.length > 0)
            grow(minCapacity);
}

private void grow(int minCapacity) {
        // overflow-conscious code
        // 容器原始大小
        int oldCapacity = elementData.length;
        // 如果capacityIncrement > 0 新大小 就等于oldCapacity + capacityIncrement 反之就等于 oldCapacity + oldCapacity 相对与2倍了。
        int newCapacity = oldCapacity + ((capacityIncrement > 0) ?
                                         capacityIncrement : oldCapacity);
        if (newCapacity - minCapacity < 0)
            newCapacity = minCapacity;
        // 判断新大小是否超过大限制
        if (newCapacity - MAX_ARRAY_SIZE > 0)
            newCapacity = hugeCapacity(minCapacity);
        // 复制生成新的数组
        elementData = Arrays.copyOf(elementData, newCapacity);
}

private static int hugeCapacity(int minCapacity) {
        if (minCapacity < 0) // overflow
            throw new OutOfMemoryError();
        return (minCapacity > MAX_ARRAY_SIZE) ?
            Integer.MAX_VALUE :
            MAX_ARRAY_SIZE;
}
最近更新: 2025/12/27 18:51
Contributors: 庆峰
Prev
Java Stack
Next
CentOS7 RabbitMQ 部署