`

多线程之ReentrantLock学习

 
阅读更多
package com.test;

public interface IBuffer {  
    public void write();  
    public void read() throws InterruptedException;  
}  



package com.test;

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;
public class BufferInterruptibly implements IBuffer {  
  
	//ReentrantLock :可在一个方法中获取  在令一个方法中释放的锁
    private Lock lock = new ReentrantLock();  
  
    public void write() {  
        lock.lock();  
        try {  
            long startTime = System.currentTimeMillis();  
            System.out.println("开始往这个buff写入数据…");  
            for (;;)// 模拟要处理很长时间  
            {  
                if (System.currentTimeMillis() - startTime > Integer.MAX_VALUE)  
                    break;  
            }  
            System.out.println("终于写完了");  
        } finally {  
            lock.unlock();  
        }  
    }  
  
    public void read() throws InterruptedException{  
    	/**
    	 * lockInterruptibly()方法,说明该线程调用该read方法时可以被中断,不比等待write方法结束 释放锁
    	 * lock()方法 说明 read方法 和write 保持同一把锁 ,只有write方法释放该锁 read方法才可操作 否则持续登录 直到获取该锁
    	 */
        lock.lockInterruptibly();// 注意这里,可以响应中断  
        //lock.lock() ;
        try {  
            System.out.println("从这个buff读数据");  
        } finally {  
            lock.unlock();  
        }  
    }  
  
} 



package com.test;

public class Test {  
   public static void main(String[] args) {  
       IBuffer buff = null;  
      
       buff = new BufferInterruptibly();     
       final Writer writer = new Writer(buff);  
       final Reader reader = new Reader(buff);  
       writer.start();  
	   try {
			Thread.sleep(2000) ;
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
       reader.start();  
       new Thread(new Runnable() {  
           public void run() {  
               long start = System.currentTimeMillis();  
               for (;;) {  
                   // 等5秒钟去中断读  
                   if (System.currentTimeMillis() - start > 5000) {  
                       System.out.println("不等了,尝试中断");  
                       reader.interrupt();  
                       break;  
                   }  
 
               }  
               System.out.println("检测终端线程结束");
 
           }  
       }).start();  
   }      
}  
 
   class Writer extends Thread {     
       private IBuffer buff;  
     
       public Writer(IBuffer buff) {  
           this.buff = buff;  
       }  
     
       @Override  
       public void run() {  
    	   System.out.println("write线程开始。。。");
           buff.write();  
           System.out.println("write线程结束!");
       }  
   }  
     
   class Reader extends Thread {  
       private IBuffer buff;  
       public Reader(IBuffer buff) {  
           this.buff = buff;  
       }  
       @Override  
       public void run() {  
           try {  
        	   System.out.println("read线程开始...");
               buff.read();  
           } catch (InterruptedException e) {  
               System.out.println("我不读了");     
           }  
           System.out.println("read结束!");  
       }  
   }  



运行结果:
write线程开始。。。
开始往这个buff写入数据…
read线程开始...
不等了,尝试中断
我不读了
read结束!
检测终端线程结束
分享到:
评论

相关推荐

    Java多线程之ReentrantLock与Condition - 平凡希 - 博客园1

    1、ReentrantLock简介 2、ReentrantLock函数列表 3、重入的实现 4、公平锁与非公平锁 5、ReentrantLock 扩展的功能 6

    Java多线程ReentrantLock1

    Java多线程ReentrantLock1

    Java多线程中ReentrantLock与Condition详解

    主要介绍了Java多线程中ReentrantLock与Condition详解,需要的朋友可以参考下

    Java多线程 ReentrantLock互斥锁详解

    主要介绍了Java多线程 ReentrantLock互斥锁详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

    java ReentrantLock详解.docx

    ReentrantLock ...ReentrantLock也可重入,但加锁和解锁需要手动进行,且次数需一样,否则其他线程无法获得锁。 3.synchronized不可响应中断,一个线程获取不到锁就一直等着;ReentrantLock可以相应中断。

    java多线程系列(四)ReentrantLock的使用.docx

    ReentrantLock类可以唤醒指定条件的线程,而object的唤醒是随机的 Condition类和Object类 Condition类的awiat方法和Object类的wait方法等效 Condition类的signal方法和Object类的notify方法等效 Condition类...

    Java 多线程与并发(11-26)-JUC锁- ReentrantLock详解.pdf

    Java 多线程与并发(11_26)-JUC锁_ ReentrantLock详解

    2023年最新Java高并发多线程面试题

    包含线程池,并发集合,volatile,CountDownLatch,Semaphore,Phaser,AQS,ReentrantLock,ReentrantLock等等问题, 用简洁明了的语言,通俗易懂地阐述了高并发多线程相关面试的知识点。 适用人群:适合想了解或...

    ReentrantLock代码剖析之ReentrantLock_lock

    ReentrantLock源码剖析

    详解Java多线程编程中互斥锁ReentrantLock类的用法

    Java多线程并发的程序中使用互斥锁有synchronized和ReentrantLock两种方式,这里我们来详解Java多线程编程中互斥锁ReentrantLock类的用法:

    多线程(11)ReentrantLock公平锁与非公平锁(修改)1

    private static class MyReentrantLock extends ReentrantLock {public MyReentrantLo

    locks框架_ReentrantLock.pdf

    Locks 框架概述: 简要介绍 Locks 框架,解释其在多线程编程中的作用和优势。比较 Locks 框架与传统 synchronized 关键字的不同之处。 ReentrantLock 简介: 详细讲解 ReentrantLock 的概念和特点。解释为什么它被...

    基于Java多线程与线程安全实践(源码+使用文档)

    基于Java多线程与线程安全实践是一个旨在展示如何在Java环境中高效、安全地使用多线程技术的系统。该系统通过结合源码示例和详细的使用文档,帮助开发者深入理解并实践线程安全的概念。 主要功能 线程安全示例:...

    2020面试题总结多线程篇.pdf

    面试题总结——多线程篇 一、多线程实现方式 多线程实现方式主要有四种:继承 Thread 类、实现 Runable 接口、实现 Callable 接口、通过 FutureTask 包装器。这四种方式可以满足不同的需求,例如继承 Thread 类...

    java多线程每个线程挨着打印ABC的4种实现方式

    java多线程每个线程挨着打印ABC的4种实现方式,有4个线程t1、t2、t3、t4,t1打印A后t2打印A再t3打印A再t4打印A,然后从新回到t1打印B再t2打印B...t4打印B... 4个线程轮流打印abc... 一个线程可以理解为一个人,打印...

    java多线程安全性基础介绍.pptx

    java多线程安全性基础介绍 线程安全 正确性 什么是线程安全性 原子性 竞态条件 i++ 读i ++ 值写回i 可见性 JMM 由于cpu和内存加载速度的差距,在两者之间增加了多级缓存导致,内存并不能直接对cpu可见。 ...

    个人总结的深入java多线程开发

    看完《think in java》多线程章节,自己写的多线程文档,还结合了其他的相关网络资料。 线程 一. 线程池 1)为什么要使用线程池 2 2)一个具有线程池的工作队列 3 3)使用线程池的风险: 4 4)有效使用线程池的原则 5...

    ReentrantLock与synchronized区别

    java语言 并发编程 ReentrantLock与synchronized区别 详解

    【2018最新最详细】并发多线程教程

    【2018最新最详细】并发多线程教程,课程结构如下 1.并发编程的优缺点 2.线程的状态转换以及基本操作 3.java内存模型以及happens-before规则 4.彻底理解synchronized 5.彻底理解volatile 6.你以为你真的了解final吗...

    Java多线程编程.docx

    Java 多线程编程 Java 多线程编程是指在 Java 语言中使用多个线程来执行不同的任务,以提高程序的执行效率和响应速度。本文将详细介绍 Java 多线程编程的基本概念、创建线程的方法、线程同步的方法和多线程编程的...

Global site tag (gtag.js) - Google Analytics