Java多线程进阶——常见的锁策略

简介: Java多线程进阶——常见的锁策略

1.乐观锁VS悲观锁


这是两种不同的加锁态度:


乐观锁:预测锁冲突的概率不高,所以做的工作比较少一点(简单一点),但效率更高。


悲观锁:预测锁冲突的概率较高,所以做的工作比较多一点(复杂一点),效率更低。


就像我们在与人合租一间房时,A在上厕所时,就比较乐观,觉得这个时候B不会去上厕所,于是就没有锁门(乐观锁)。

而B在上厕所时,就比较悲观,觉得这个时候A来上厕所的概率比较大,于是就上锁了(悲观锁)。


2.读写锁VS普通互斥锁


普通互斥锁:就如同synchronized,当两个线程竞争同一把锁时,就会产生竞争


读写锁:具有加读锁和加写锁两个操作。

读锁和读锁之间,不会产生竞争;写锁和写锁之间会产生竞争;读锁和写锁之间也有竞争。

在实际场景中,读的操作要比写的操作多很多,读写锁要比普通的互斥锁少了很多的锁竞争,优化了效率。


3.重量级锁VS轻量级锁


重量级锁:加锁解锁开销比较大(涉及到进入内核态的加锁逻辑,开销比较大)


轻量级锁:加锁解锁开销比较小(纯用户态的加锁逻辑,开销比较小)


乐观锁/悲观锁是站在加锁/解锁的过程中干的工作的多少看待的。

而重量级锁/轻量级锁是站在加锁/解锁消耗的时间多少看待的。


在通常情况下,干的工作多,消耗的时间也多,因此,一般乐观锁也比较轻量。悲观锁,一般比较重量。


4.自旋锁VS挂起等待锁


自旋锁:在获取锁失败以后,不会立刻释放CPU,而是不断的询问锁的持有状态,一旦锁被释放,就能立刻获取到锁,是轻量级锁的一种典型表现。(自旋就类似于在定时器一篇文章中出现的忙等,消耗了大量CPU,反复询问当前锁是否就绪)


挂起等待锁:在获取锁失败以后,对应的线程就会在内核中挂起等待(放弃CPU,进入等待队列),在锁被释放后由操作系统唤醒,是重量级锁的一种典型实现。


5.公平锁VS非公平锁


公平锁:遵循先来后到的规则,在多个线程等待同一把锁时,谁先来尝试拿锁,那这把锁就是谁的。


非公平锁:遵循随机的规则,在多个线程等待同一把锁时,锁如果释放,每个线程获取到锁的概率是相同的。


6.可重入锁VS不可重入锁


一个线程连续加锁两次,不会造成死锁,就是可重入锁;

反之,如果造成死锁,就是不可重入锁。


7.synchronized特性


对于synchronized:


1.既是乐观锁,也是悲观锁

2.既是轻量级锁,也是重量级锁

3.乐观锁的部分是基于自旋锁实现的,悲观锁的部分是基于挂起等待锁实现的


(synchronized是自适应锁,在初始使用的时候,是乐观锁/轻量级锁/自旋锁,如果锁竞争变的激烈了,synchronized会自动升级成悲观锁/重量级锁/挂起等待锁)


4.不是读写锁,是普通互斥锁

5.是非公平锁

6.是可重入锁

相关文章
|
1天前
|
缓存 Java
java中的公平锁、非公平锁、可重入锁、递归锁、自旋锁、独占锁和共享锁
本文介绍了几种常见的锁机制,包括公平锁与非公平锁、可重入锁与不可重入锁、自旋锁以及读写锁和互斥锁。公平锁按申请顺序分配锁,而非公平锁允许插队。可重入锁允许线程多次获取同一锁,避免死锁。自旋锁通过循环尝试获取锁,减少上下文切换开销。读写锁区分读锁和写锁,提高并发性能。文章还提供了相关代码示例,帮助理解这些锁的实现和使用场景。
java中的公平锁、非公平锁、可重入锁、递归锁、自旋锁、独占锁和共享锁
|
3天前
|
存储 设计模式 分布式计算
Java中的多线程编程:并发与并行的深度解析####
在当今软件开发领域,多线程编程已成为提升应用性能、响应速度及资源利用率的关键手段之一。本文将深入探讨Java平台上的多线程机制,从基础概念到高级应用,全面解析并发与并行编程的核心理念、实现方式及其在实际项目中的应用策略。不同于常规摘要的简洁概述,本文旨在通过详尽的技术剖析,为读者构建一个系统化的多线程知识框架,辅以生动实例,让抽象概念具体化,复杂问题简单化。 ####
|
4天前
|
Java 开发者
在Java多线程编程的世界里,Lock接口正逐渐成为高手们的首选,取代了传统的synchronized关键字
在Java多线程编程的世界里,Lock接口正逐渐成为高手们的首选,取代了传统的synchronized关键字
19 4
|
4天前
|
消息中间件 供应链 Java
掌握Java多线程编程的艺术
【10月更文挑战第29天】 在当今软件开发领域,多线程编程已成为提升应用性能和响应速度的关键手段之一。本文旨在深入探讨Java多线程编程的核心技术、常见问题以及最佳实践,通过实际案例分析,帮助读者理解并掌握如何在Java应用中高效地使用多线程。不同于常规的技术总结,本文将结合作者多年的实践经验,以故事化的方式讲述多线程编程的魅力与挑战,旨在为读者提供一种全新的学习视角。
24 3
|
5天前
|
安全 Java 调度
Java中的多线程编程入门
【10月更文挑战第29天】在Java的世界中,多线程就像是一场精心编排的交响乐。每个线程都是乐团中的一个乐手,他们各自演奏着自己的部分,却又和谐地共同完成整场演出。本文将带你走进Java多线程的世界,让你从零基础到能够编写基本的多线程程序。
17 1
|
9天前
|
缓存 Java 调度
Java中的多线程编程:从基础到实践
【10月更文挑战第24天】 本文旨在为读者提供一个关于Java多线程编程的全面指南。我们将从多线程的基本概念开始,逐步深入到Java中实现多线程的方法,包括继承Thread类、实现Runnable接口以及使用Executor框架。此外,我们还将探讨多线程编程中的常见问题和最佳实践,帮助读者在实际项目中更好地应用多线程技术。
17 3
|
6月前
|
安全 Java
深入理解Java并发编程:线程安全与性能优化
【2月更文挑战第22天】在Java并发编程中,线程安全和性能优化是两个重要的主题。本文将深入探讨这两个主题,包括线程安全的基本概念,如何实现线程安全,以及如何在保证线程安全的同时进行性能优化。
55 0
|
6月前
|
存储 安全 Java
深入理解Java并发编程:线程安全与锁机制
【5月更文挑战第31天】在Java并发编程中,线程安全和锁机制是两个核心概念。本文将深入探讨这两个概念,包括它们的定义、实现方式以及在实际开发中的应用。通过对线程安全和锁机制的深入理解,可以帮助我们更好地解决并发编程中的问题,提高程序的性能和稳定性。
|
3月前
|
存储 安全 Java
解锁Java并发编程奥秘:深入剖析Synchronized关键字的同步机制与实现原理,让多线程安全如磐石般稳固!
【8月更文挑战第4天】Java并发编程中,Synchronized关键字是确保多线程环境下数据一致性与线程安全的基础机制。它可通过修饰实例方法、静态方法或代码块来控制对共享资源的独占访问。Synchronized基于Java对象头中的监视器锁实现,通过MonitorEnter/MonitorExit指令管理锁的获取与释放。示例展示了如何使用Synchronized修饰方法以实现线程间的同步,避免数据竞争。掌握其原理对编写高效安全的多线程程序极为关键。
62 1
|
4月前
|
安全 Java 开发者
Java并发编程中的线程安全问题及解决方案探讨
在Java编程中,特别是在并发编程领域,线程安全问题是开发过程中常见且关键的挑战。本文将深入探讨Java中的线程安全性,分析常见的线程安全问题,并介绍相应的解决方案,帮助开发者更好地理解和应对并发环境下的挑战。【7月更文挑战第3天】
88 0