为什么不推荐使用Vector

为什么不推荐使用Vector,第1张

为什么不推荐使用Vector

Vector的底层与ArrayList类似.都是以动态数组的方式进行对象的存储

Vector与ArrayList的区别在于Vector是线程同步 *** 作安全的

Vector的并发安全保证

看Vector的源码(如下)发现很多对外的方法都用Synchronized关键字进行修饰

所以通过vector进行 *** 作性能并不高,因此慢慢被放弃

public synchronized void addElement(E obj) {
    modCount++;
    ensureCapacityHelper(elementCount + 1);
    elementData[elementCount++] = obj;
}

public synchronized boolean removeElement(Object obj) {
    modCount++;
    int i = indexOf(obj);
    if (i >= 0) {
        removeElementAt(i);
        return true;
    }
    return false;
}

public synchronized E get(int index) {
    if (index >= elementCount)
        throw new ArrayIndexOutOfBoundsException(index);

    return elementData(index);
}

如上可知,Vector是线程安全的,但是性能较差,不推荐使用。
在工作中,我们有可能将集合(ArrayList与linkedList)转换为线程安全。
就要用到Collection工具类
集合转换为线程安全的对象

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5660078.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-16
下一篇 2022-12-16

发表评论

登录后才能评论

评论列表(0条)

保存