HashMap 和 HashTable的区别
HashMap 和 HashTable都实现 Map接口,都是键值对保存数据的方式
区别1:
- HashMap 可以存放 null
- HashTable 不能存放 null
区别二:
- HashMap 不是线程安全的类
- HashTable 是线程安全的类
StringBuffer 和 StringBuilder 的区别
区别1:
- StringBuffer 是线程安全的
- StringBuilder 是非线程安全的
所以当进行大量字符串拼接操作的时候,如果是单线程就用StringBuilder会更快些(不需要同步,省略了些时间);如果是多线程,就需要用StringBuffer 保证数据的安全性。
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是非线程安全的。
把非线程安全的集合转换为线程安全
ArrayList是非线程安全的,换句话说,多个线程可以同时进入一个ArrayList对象的add方法
借助Collections.synchronizedList,可以把ArrayList转换为线程安全的List。
与此类似的,还有HashSet,LinkedList,HashMap等等非线程安全的类,都通过工具类Collections转换为线程安全的
package multiplethread;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
public class TestThread {
public static void main(String[] args) {
List<Integer> list1 = new ArrayList<>();
List<Integer> list2 = Collections.synchronizedList(list1);
}
}