推荐链接:
总结——》【Java】
总结——》【Mysql】
总结——》【Redis】
总结——》【Kafka】
总结——》【Spring】
总结——》【SpringBoot】
总结——》【MyBatis、MyBatis-Plus】
总结——》【Linux】
总结——》【MongoDB】
总结——》【Elasticsearch】
Java——》如何保证线程的安全性
- 一、加锁
- 1、悲观锁
- 2、乐观锁
- 二、不加锁
Q:如果存在临界(共享)资源,如何保证线程的安全性?
A:加锁,怎么做?不加锁,怎么做?
一、加锁
1、悲观锁
synchronized
、Lock
(ReentrantLock,ReadWriteLock)
2、乐观锁
CAS
Q:CAS真的无锁吗?
A:
Java层面:没锁,基于Unsafe实现
C++层面:有锁,lock cmpexchg
二、不加锁
ThreadLocal
:让多个线程将共享资源copy到本地,没有多线程操作共享资源的问题volatile
:只要不包含并发对共享数据进行运算,基本没问题。