gpt4 book ai didi

Java并发编程之ReadWriteLock读写锁的操作方法

转载 作者:qq735679552 更新时间:2022-09-29 22:32:09 27 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章Java并发编程之ReadWriteLock读写锁的操作方法由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

1.ReadWriteLock介绍 。

Java并发编程之ReadWriteLock读写锁的操作方法

为什么我们有了Lock,还要用ReadWriteLock呢。我们对共享资源加锁之后,所有的线程都将会等待。Lock读操作也锁,写操作也会锁,而对共享资源读的时候,其实是不用加锁的。当然读写同时存在的情况也会有。 比如我们数据库常用操作有增删改查,增删改都是写操作,写操作必须加锁,而读操作可以共享。不是所有的操作都需要加锁。 为了进一步提高复用性和粒度,写操作独占,读操作共享,不加锁。 ReadWriteLock管理一组锁,一个是只读的锁,一个是写锁。读锁可以在没有写锁的时候被多个线程同时持有,写锁是独占的。 即读读可共享,写读写写要独占 读操作不用关心资源争抢和数据一致性的操作 。

多个线程同时读一个资源类没有任何问题,所以为了满足并发量,读取共享资源应该可以同时进行。 但是如果有一个线程想去写共享资源来,就不应该再有其它线程可以对该资源进行读或写。 小总结:   读-读能共存   读-写不能共存   写-写不能共存 。

ReadWriteLock适用于读多写少的并发情况。 Java并发包中ReadWriteLock是一个接口,主要有两个方法,如下:

  1. public interface ReadWriteLock {
  2. /**
  3. * 返回读锁
  4. */
  5. Lock readLock();
  6.  
  7. /**
  8. * 返回写锁
  9. */
  10. Lock writeLock();
  11. }

Java并发库中ReetrantReadWriteLock实现了ReadWriteLock接口并添加了可重入的特性.

2.不用读写锁的案例 。

  1. class MyCache{
  2. //volalite保证数据再线程间的可见性和一定的有序性
  3. private volatile Map<String,Object> map=new HashMap<>();
  4. public void put(String key,Object value){
  5. System.out.println(Thread.currentThread().getName()+"\t ---写入数据"+key);
  6. map.put(key,value);
  7. try {TimeUnit.SECONDS.sleep(3);} catch (InterruptedException e) {e.printStackTrace();}
  8. System.out.println(Thread.currentThread().getName()+"\t ---写入完成");
  9. }
  10. public void get(String key){
  11. System.out.println(Thread.currentThread().getName()+"\t 读取数据");
  12. Object result=map.get(key);
  13. System.out.println(Thread.currentThread().getName()+"\t 读取完成"+result);
  14. }
  15.  
  16. }
  17. public class ReadWriteLockDemo {
  18.  
  19. public static void main(String[] args) {
  20. // TODO Auto-generated method stub
  21. MyCache myCache=new MyCache();
  22. for(int i=1;i<=5;i++){
  23. final int tempInt=i;
  24. new Thread(()->{
  25. myCache.put(tempInt+"",tempInt+"");
  26.  
  27. },String.valueOf(i)).start();
  28. }
  29. for(int i=1;i<=5;i++){
  30. final int tempInt=i;
  31. new Thread(()->{
  32. myCache.get(tempInt+"");
  33.  
  34. },String.valueOf(i)).start();
  35. }
  36. }
  37. }

Java并发编程之ReadWriteLock读写锁的操作方法

上面的运行结果出现了一个很严重的问题,比如说,线程1在写入数据的时候,还没等线程1写完,其它线程也在写和读。这违背了事务的原子性。而且也破坏了数据的完整性和一致性,我正在写的时候,不允许其他线程同时也在写或者读。即1写入的时候,必须要满足后一条就是1写入完成.

3.用读写锁的案例 。

  1. class MyCache{
  2. //volalite保证数据再线程间的可见性和一定的有序性
  3. private volatile Map<String,Object> map=new HashMap<>();
  4. private ReadWriteLock readwritelock=new ReentrantReadWriteLock();
  5. public void put(String key,Object value){
  6. readwritelock.writeLock().lock();
  7. try {
  8. System.out.println(Thread.currentThread().getName()+"\t ---写入数据"+key);
  9. map.put(key,value);
  10. try {TimeUnit.SECONDS.sleep(3);} catch (InterruptedException e) {e.printStackTrace();}
  11. System.out.println(Thread.currentThread().getName()+"\t ---写入完成");
  12. } catch (Exception e) {
  13. // TODO: handle exception
  14. e.printStackTrace();
  15. }finally{
  16. readwritelock.writeLock().unlock();
  17. }
  18. }
  19. public void get(String key){
  20. readwritelock.readLock().lock();
  21. try {
  22. System.out.println(Thread.currentThread().getName()+"\t 读取数据");
  23. Object result=map.get(key);
  24. System.out.println(Thread.currentThread().getName()+"\t 读取完成"+result);
  25. } catch (Exception e) {
  26. // TODO: handle exception
  27. e.printStackTrace();
  28. }finally{
  29. readwritelock.readLock().unlock();
  30. }
  31.  
  32. }
  33.  
  34. }
  35. public class ReadWriteLockDemo {
  36.  
  37. public static void main(String[] args) {
  38. // TODO Auto-generated method stub
  39. MyCache myCache=new MyCache();
  40. for(int i=1;i<=5;i++){
  41. final int tempInt=i;
  42. new Thread(()->{
  43. myCache.put(tempInt+"",tempInt+"");
  44.  
  45. },String.valueOf(i)).start();
  46. }
  47. for(int i=1;i<=5;i++){
  48. final int tempInt=i;
  49. new Thread(()->{
  50. myCache.get(tempInt+"");
  51.  
  52. },String.valueOf(i)).start();
  53. }
  54. }
  55. }

Java并发编程之ReadWriteLock读写锁的操作方法

到此这篇关于Java并发编程之ReadWriteLock读写锁的文章就介绍到这了,更多相关java ReadWriteLock读写锁内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。

原文链接:https://blog.csdn.net/qq_39736597/article/details/113331843 。

最后此篇关于Java并发编程之ReadWriteLock读写锁的操作方法的文章就讲到这里了,如果你想了解更多关于Java并发编程之ReadWriteLock读写锁的操作方法的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com