- 从线程是否需要对资源加锁可以分为 悲观锁 和 乐观锁
- 从资源已被锁定,线程是否阻塞可以分为 自旋锁
- 从多个线程并发访问资源,也就是 Synchronized 可以分为 无锁、偏向锁、 轻量级锁 和 重量级锁
- 从锁的公平性进行区分,可以分为公平锁 和 非公平锁
- 从根据锁是否重复获取可以分为 可重入锁 和 不可重入锁
- 从那个多个线程能否获取同一把锁分为 共享锁 和 排他锁(独享锁)
什么是串行、并发、并行
- 串行:一个线程执行到底,相当于单线程。
- 并发:多个线程交替执行,抢占cpu的时间片,但是速度很快,在外人看来就像是多个线程同时执行。
- 并行:多个线程在不同的cpu中同时执行。
并发与并行的区别
-
并发严格的说不是同时执行多个线程,只是
线程交替执行且速度很快,相当于同时执行
。 -
而并行是同时执行多个线程,也就是多个cpu核心同时执行多个线程。