谈谈ArrayList与Vector的理解?

目录

扩容机制

ArrayList扩容源码

Vector扩容源码

二者区别

[扩展:stack(栈)](#扩展:stack(栈))

1.创建stack对象

[2. 入栈(先进后出)](#2. 入栈(先进后出))

3.出栈

扩展:举个例子:实现下字符串逆置,利用stack栈来实现。


从接口实现上,ArrayList与Vector都是基于动态数组实现的List接口的集合实现类。

扩容机制

ArrayList扩容源码

复制代码
private void grow(int minCapacity) {
    // overflow-conscious code
    int oldCapacity = elementData.length;
    int newCapacity = oldCapacity + (oldCapacity >> 1);
    if (newCapacity - minCapacity < 0)
        newCapacity = minCapacity;
    if (newCapacity - MAX_ARRAY_SIZE > 0)
        newCapacity = hugeCapacity(minCapacity);
    // minCapacity is usually close to size, so this is a win:
    elementData = Arrays.copyOf(elementData, newCapacity);
  • 当传入的是无参构造时候,add(11)个元素时候,会进行扩容,新容量为oldCapacity>>1+oldCapacity;
  • 当传入的是带参构造,扩容时候,会按照它的传入的扩容容量+扩容容量<<1进行计算;

Vector扩容源码

复制代码
private void grow(int minCapacity) {
    // overflow-conscious code
    int oldCapacity = elementData.length;
    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);
}
复制代码
Vector 的无参构造,数组的初始化容量为10,每次扩容不足,扩容为原来的二倍
复制代码
初始化提供数组的初始化容量和每次的扩容值,当容量不足时候,已指定扩容值进行扩容操作

二者区别

初始容量:

  1. ArrayList初始默认容量为0,添加一个元素时候,扩容为10;
  2. Vector 初始容量为10;

扩容方式:

  1. ArrayList:在原有容量基础上,扩容1.5倍。
  2. Vector:在原有容量基础上,扩容2倍。

线程安全:

  1. ArrayList:线程不安全(可使用CopyWriteArrayList集合解决)
  2. Vector:线程安全,操作方法使用sychronized(同步锁)实现线程同步。

执行效率:

  1. Vector的方法加入了同步锁,实现线程安全,所以在方法执行时许加锁,释放锁,产生额外的性能开销,所以Vector性能会低于ArrayList.

    // 栈 先进后出
    Stack<String> stack = new Stack<>();
    // 入栈
    stack.push("张三");
    stack.push("李四");
    stack.push("王五");
    System.out.println(stack);
    // 获取到栈顶元素,并让栈顶元素出栈
    // String item = S1.POP();
    // 获取栈顶元素,元素不出栈。
    String item = stack.peek();
    System.out.println(item);
    System.out.println(stack);

    复制代码
         // 字符串逆置
    
         System.out.println(reverse("abcdefg"));
     }
     public static String reverse(String str){
         Stack<Character> stack = new Stack<>();
    
         // 字符串中的元素入栈
         char[] c1 = str.toCharArray();
         for (char c : c1){
             stack.push(c);
         }
         StringBuilder sb = new StringBuilder();
    
         // 出栈
         while (!stack.isEmpty()){
             sb.append(stack.pop());
         }
         return sb.toString();
     }

扩展:stack(栈)

1.创建stack对象

复制代码
        Stack<Character> stack = new Stack<>();

2. 入栈(先进后出)

复制代码
        stack.push("张三");

3.出栈

复制代码
        // 获取到栈顶元素,并让栈顶元素出栈
        // String item = S1.pop();


        // 获取栈顶元素,元素不出栈。
        String item = stack.peek();

扩展:举个例子:实现下字符串逆置,利用stack栈来实现。

复制代码
public static String reverse(String str){
        Stack<Character> stack = new Stack<>();

        // 字符串中的元素入栈
        char[] c1 = str.toCharArray();
        for (char c : c1){
            stack.push(c);
        }
        StringBuilder sb = new StringBuilder();

        // 出栈
        while (!stack.isEmpty()){
            sb.append(stack.pop());
        }
        return sb.toString();
    }
相关推荐
charlie11451419118 分钟前
嵌入式的现代C++教程——constexpr与设计技巧
开发语言·c++·笔记·单片机·学习·算法·嵌入式
清木铎2 小时前
leetcode_day4_筑基期_《绝境求生》
算法
清木铎2 小时前
leetcode_day10_筑基期_《绝境求生》
算法
j_jiajia2 小时前
(一)人工智能算法之监督学习——KNN
人工智能·学习·算法
源代码•宸2 小时前
Golang语法进阶(协程池、反射)
开发语言·经验分享·后端·算法·golang·反射·协程池
Jasmine_llq4 小时前
《CF280C Game on Tree》
数据结构·算法·邻接表·深度优先搜索(dfs)·树的遍历 + 线性累加统计
小棠师姐4 小时前
支持向量机(SVM)入门:超平面与核函数的通俗解释
算法·python机器学习·支持向量机svm·超平面可视化·核函数应用
im_AMBER4 小时前
Leetcode 102 反转链表
数据结构·c++·学习·算法·leetcode·链表
今儿敲了吗5 小时前
01|多项式输出
c++·笔记·算法
Xの哲學5 小时前
深入剖析Linux文件系统数据结构实现机制
linux·运维·网络·数据结构·算法