多线程(四)——重入锁和读写锁以及CAS无锁机制

2024-02-23 06:32

本文主要是介绍多线程(四)——重入锁和读写锁以及CAS无锁机制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概念:

1、在java环境下ReentrantLock和synchronized都是可重入锁
2、非重入锁会导致死锁
3、重入锁,传递给下一个方法,重复使用

重入锁测试代码:

package thread.pool;/*** 重入锁、非重入锁* @author Administrator**/
public class Test5 implements Runnable {public synchronized void get(){System.out.println(Thread.currentThread().getId() +"---get()");set();}public synchronized void set(){System.out.println(Thread.currentThread().getId() +"---set()");}@Overridepublic void run() {get();}public static void main(String[] args) {Test5 th = new Test5();new Thread(th).start();new Thread(th).start();new Thread(th).start();new Thread(th).start();new Thread(th).start();}
}
package thread.pool;import java.util.concurrent.locks.ReentrantLock;/*** 重入锁、非重入锁* @author Administrator**/
public class Test6 implements Runnable {ReentrantLock dd = new ReentrantLock();public void get(){dd.lock();System.out.println(Thread.currentThread().getId() +"---get()");set();dd.unlock();}public void set(){dd.lock();System.out.println(Thread.currentThread().getId() +"---set()");dd.unlock();}@Overridepublic void run() {get();}public static void main(String[] args) {Test6 th = new Test6();new Thread(th).start();new Thread(th).start();new Thread(th).start();new Thread(th).start();new Thread(th).start();}
}

读写锁的测试代码:

package thread.pool;import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantReadWriteLock;/*** * 读写锁* * @author Administrator**/
public class Test7 {static Map<String, Object> map = new HashMap<>();static ReentrantReadWriteLock da = new ReentrantReadWriteLock();static Lock r = da.readLock();static Lock w = da.writeLock();public static void get(String key) {r.lock();System.out.println(""+key+"正在进行----读----操作-----开始");try {Thread.sleep(100);Object object = map.get(key);System.out.println(""+key+"-"+object+"正在进行----读---操作-----结束");} catch (InterruptedException e) {e.printStackTrace();}finally {r.unlock();}}public static void set(String key, String value) {w.lock();System.out.println(""+key+"-"+value+"正在进行----写----操作-----开始");try {Thread.sleep(100);map.put(key, value);System.out.println(""+key+"-"+value+"正在进行----写----操作-----结束");} catch (InterruptedException e) {e.printStackTrace();}finally {w.unlock();}}public static void main(String[] args) {new Thread(new Runnable() {@Overridepublic void run() {for (int i = 0; i < 10; i++) {Test7.get(i+"");}}}).start();new Thread(new Runnable() {@Overridepublic void run() {for (int i = 0; i < 10; i++) {Test7.set(i+"", i+"");}}}).start();}
}

4、CAS无锁机制
举例:原子类底层实现保证线程安全,就是采用CAS无锁机制,CAS无锁机制效率比有效机制高
5、CAS体系中有三个参数,它包含三个参数CAS(V,E,N):v表示要更新的变量值,E表示预期值,N表示新值。仅当V值等于E值时,才会将V的值设为N,如果V值和E值不同,则说明已经有其他线程做了更新,则当前线程什么都不会做。最后,CAS返回当前V的真实值

 

这篇关于多线程(四)——重入锁和读写锁以及CAS无锁机制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/737788

相关文章

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

Javaee多线程之进程和线程之间的区别和联系(最新整理)

《Javaee多线程之进程和线程之间的区别和联系(最新整理)》进程是资源分配单位,线程是调度执行单位,共享资源更高效,创建线程五种方式:继承Thread、Runnable接口、匿名类、lambda,r... 目录进程和线程进程线程进程和线程的区别创建线程的五种写法继承Thread,重写run实现Runnab

C#读写文本文件的多种方式详解

《C#读写文本文件的多种方式详解》这篇文章主要为大家详细介绍了C#中各种常用的文件读写方式,包括文本文件,二进制文件、CSV文件、JSON文件等,有需要的小伙伴可以参考一下... 目录一、文本文件读写1. 使用 File 类的静态方法2. 使用 StreamReader 和 StreamWriter二、二进

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

使用Python实现可恢复式多线程下载器

《使用Python实现可恢复式多线程下载器》在数字时代,大文件下载已成为日常操作,本文将手把手教你用Python打造专业级下载器,实现断点续传,多线程加速,速度限制等功能,感兴趣的小伙伴可以了解下... 目录一、智能续传:从崩溃边缘抢救进度二、多线程加速:榨干网络带宽三、速度控制:做网络的好邻居四、终端交互

MySQL中的锁机制详解之全局锁,表级锁,行级锁

《MySQL中的锁机制详解之全局锁,表级锁,行级锁》MySQL锁机制通过全局、表级、行级锁控制并发,保障数据一致性与隔离性,全局锁适用于全库备份,表级锁适合读多写少场景,行级锁(InnoDB)实现高并... 目录一、锁机制基础:从并发问题到锁分类1.1 并发访问的三大问题1.2 锁的核心作用1.3 锁粒度分

Redis的持久化之RDB和AOF机制详解

《Redis的持久化之RDB和AOF机制详解》:本文主要介绍Redis的持久化之RDB和AOF机制,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述RDB(Redis Database)核心原理触发方式手动触发自动触发AOF(Append-Only File)核

MySQL主从复制与读写分离的用法解读

《MySQL主从复制与读写分离的用法解读》:本文主要介绍MySQL主从复制与读写分离的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、主从复制mysql主从复制原理实验案例二、读写分离实验案例安装并配置mycat 软件设置mycat读写分离验证mycat读

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模

PostgreSQL中MVCC 机制的实现

《PostgreSQL中MVCC机制的实现》本文主要介绍了PostgreSQL中MVCC机制的实现,通过多版本数据存储、快照隔离和事务ID管理实现高并发读写,具有一定的参考价值,感兴趣的可以了解一下... 目录一 MVCC 基本原理python1.1 MVCC 核心概念1.2 与传统锁机制对比二 Postg