线程安全的类相关

不安全的原因是因为共享变量被多个线程调用而出现数据错乱

而前面讲到的锁就是让其同步操作,同一时刻只有一个线程可以操作这个变量,达到数据的一致性和同步性。

 步骤 1 : 

HashMap和Hashtable的区别

HashMap和Hashtable都实现了Map接口,都是键值对保存数据的方式
区别1: 
HashMap可以存放 null
Hashtable不能存放null
区别2:
HashMap不是线程安全的类
Hashtable是线程安全的类

 步骤 2 : 

StringBuffer和StringBuilder的区别

StringBuffer 是线程安全的
StringBuilder 是非线程安全的

所以当进行大量字符串拼接操作的时候,如果是单线程就用StringBuilder会更快些,如果是多线程,就需要用StringBuffer 保证数据的安全性

非线程安全的为什么会比线程安全的 快? 因为不需要同步嘛,省略了些时间

 步骤 3 : 

ArrayList和Vector的区别

通过在eclipse中查看源代码可以得知:

ArrayList类的声明:

public class ArrayList<E> extends AbstractList<E>

implements List<E>, RandomAccess, Cloneable, java.io.Serializable



Vector类的声明:

public class Vector<E> extends AbstractList<E>

implements List<E>, RandomAccess, Cloneable, java.io.Serializable



一模一样的~ 
他们的区别也在于,Vector是线程安全的类,而ArrayList是非线程安全的。

————————————————————————————————————————————————————————

Collections.synchronizedList(),可以将arraylist转换为线性安全的list

public class TestThread {

    

    public static void main(String[] args) {

        List<Integer> list1 = new ArrayList<>();

        List<Integer> list2 = Collections.synchronizedList(list1);

    }

猜你喜欢

转载自blog.csdn.net/Whiteleaf3er/article/details/82660550