- volatile:是Java虚拟机提供的轻量级的同步机制
- 1、保证可见性
- 2、不保证原子性
- 3、禁止指令重排
- ArrayList是线程不安全的集合,如何变成线程安全的呢
- new vector<>() ; 这个是jdk1.0开始的,ArrayList是jdk1.2开始,相比arraylist在add()方法加了synchrized
- Collections.synchronizedList(new ArrayList<>())
- new CopyOnWriteArrayList<>()
public boolean add(E e) {
final ReentrantLock lock = this.lock;
lock.lock();
try {
Object[] elements = getArray();
int len = elements.length;
Object[] newElements = Arrays.copyOf(elements, len + 1);
newElements[len] = e;
setArray(newElements);
return true;
} finally {
lock.unlock();
}
}
- collection是接口,list、set实现了该接口。collections是集合类,提供了集合操作相关的工具
- HashSet是基于HashMap实现的,通过其构造方法就可以发现,由于HashMap是key-value格式,所以系统会默认创建new Object()作为所有元素的value.
- 性能:硬盘< 内存 < CPU(缓存)
- 可重入锁(递归锁):线程可以进入任何一个它已经拥有的锁所同步着的代码块
- synchronized和Lock有什么区别?用新的lock有什么好处?你举例说说
- 原始构成
- synchronized是关键字,属于jvm层面。(idea 执行javap)
- monitorenter(底层是通过monitor对象来完成, 其实wait/notify等方法也依赖于monitor对象只有在同步块或方法中才能调wait/notify等方法)
- monitorexit
- lock是具体类(Java.util.concurrent.locks.lock)是api层面的锁
- synchronized是关键字,属于jvm层面。(idea 执行javap)
- 使用方法
- synchronized 不需要用户去手动释放锁,当synchronized代码执行完后系统会自动释放对锁的占用
- ReentrantLock则需要用户手动释放锁若没有主动释放锁,就有可能导致出现死锁现象。
需要lock()和unlock()方法配合try/finally语句块来完成
- 等待是否可中断
- synchronized不可中断,除非抛出异常或者正常运行完成
- ReentrantLock 可中断,
- 设置超时方法 trylock(long timeout, TimeUnit unit)
- lockInterruptibly()放代码块中,调用interrupt()方法可中断
- 加锁是否公平
- synchronized非公平锁
- ReentrantLock两者都可以,默认是非公平锁,构造方法可以传入boolean值, true为公平锁, false为非公平锁
- 锁绑定多个条件condition
- synchronized 没有
- ReentrantLock用来实现分组唤醒需要唤醒的线程们,可以精确唤醒,而不是像synchronized要么随机唤醒一个, 要么唤醒全部线程
- 原始构成
- 接口继承接口用extends关键字,用 implements 编译器会提示报错
品轩GO
致力于做一款有趣的网站
品轩GO
致力于做一款有趣的网站