不安全的原因是因为共享变量被多个线程调用而出现数据错乱
而前面讲到的锁就是让其同步操作,同一时刻只有一个线程可以操作这个变量,达到数据的一致性和同步性。
步骤 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);
}