1、哪些集合类是线程安全的?
Vector:就比ArrayList多了个同步化机制(线程安全)
HashTable:就比HashMap多了个线程安全
ConcurrentHashMap:是一种高效但是线程安全的集合
2、volatile关键字能否保证线程安全?
单纯使用 volatile 关键字是不能保证线程安全的
- volatile 只提供了一种弱的同步机制,用来确保将变量的更新操作通知到其他线程
- volatile 语义是禁用 CPU 缓存,直接从主内存读、写变量。表现为:更新 volatile 变量时,JMM 会把线程对应的本地内存中的共享变量值刷新到主内存中;读 volatile 变量时,JMM 会把线程对应的本地内存设置为无效,直接从主内存中读取共享变量
- 当把变量声明为 volatile 类型后,JVM 增加内存屏障,禁止 CPU 进行指令重排
3、简述一下HashMap与 HashTable的底层数据结构?
HashMap:数组+链表
HashTable:和HashMap相似,其基本内部数据结构是一个Entry数组