Lock锁——-tryLock()方法

Lock锁——-tryLock()方法这一次主要学习Lock接口中的**tryLock()**方法。tryLock()方法是有返回值的,返回值是Boolean类型。它表示的是用来尝试获取锁:成功获取则返回true;获取失败则返回false,这个方法无论如何都会立即返回。不会像synchronized一样,一个线程获取锁之后,其他锁只能等待那个线程释放之后才能有获取锁的机会。一般情况下的tryLock获取锁匙这样使用的://实例化…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

这一次主要学习Lock接口中的**tryLock()**方法。

tryLock()方法是有返回值的,返回值是Boolean类型。它表示的是用来尝试获取锁:成功获取则返回true;获取失败则返回false,这个方法无论如何都会立即返回。不会像synchronized一样,一个线程获取锁之后,其他锁只能等待那个线程释放之后才能有获取锁的机会。
一般情况下的tryLock获取锁匙这样使用的:

//实例化Lock接口对象
Lock lock = ...;
//根据尝试获取锁的值来判断具体执行的代码
if(lock.tryLock()) {
     try{
         //处理任务
     }catch(Exception ex){
         
     }finally{
     	//当获取锁成功时最后一定要记住finally去关闭锁
         lock.unlock();   //释放锁
     } 
}else {
	//else时为未获取锁,则无需去关闭锁
    //如果不能获取锁,则直接做其他事情
}

具体简单的使用过程如下:

package Lock;

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

/**
 * @author jc
 *
 */
public class TryLock {
	//实例化Lock对象
	Lock lock = new ReentrantLock();

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		//实例化本类对象,目的是调用runThread方法
		TryLock tl = new TryLock();
		//匿名对象创建线程1,并重写run方法,启动线程
		new Thread(){
			public void run(){
				
				tl.runThread(Thread.currentThread());
			}
		}.start();
		//匿名对象创建线程2,并重写run方法,启动线程
		new Thread(){
			public void run(){
				
				tl.runThread(Thread.currentThread());
			}
		}.start();
		
		
	}
	//线程共同调用方法
	public void runThread(Thread t){
		//lock对象调用trylock()方法尝试获取锁
		if(lock.tryLock()){
			//获锁成功代码段
			System.out.println("线程"+t.getName()+"获取锁成功");
			try {
				//执行的代码
				Thread.sleep(5000);
			} catch (Exception e) {
				//异常处理内容,比如中断异常,需要恢复等
			} finally {
				//获取锁成功之后,一定记住加finally并unlock()方法,释放锁
				System.out.println("线程"+t.getName()+"释放锁");
				lock.unlock();
			}
		}else{
			//获锁失败代码段
			//具体获取锁失败的回复响应
			System.out.println("线程"+t.getName()+"获取锁失败");
		}
	}
}
/**
 * output
 * 线程Thread-0获取锁成功
 * 线程Thread-1获取锁失败
 * 线程Thread-0释放锁
 */

通过代码可以看到,Thread-0获取锁成功,Thread-1获取锁失败直接退出到else中执行else代码块。Thread-0执行sleep()方法过后正常释放锁。

tryLock()有一个重载方法,这个方法就是:**tryLock(long time , TimeUnit unit)**方法,这个方法去限定了一个尝试获取锁的时间。
—获取锁成功则返回true;
—当失败是分为两种情况:
在参数范围内,则不会立即返回值,会等待一段时间,这个时间就是传入的具体参数值,在这个时间内获取锁成功,则依旧返回true;
当过了参数范围后,还是获取锁失败,则立即返回false。
使用过程和tryLock()方法一样:

Lock lock = ...;
//根据尝试获取锁的值来判断具体执行的代码
if(lock.tryLock(long time , TimeUnit unit)) {
     try{
         //处理任务
     }catch(Exception ex){
         
     }finally{
     	//当获取锁成功时最后一定要记住finally去关闭锁
         lock.unlock();   //释放锁
     } 
}else {
	//else时为未获取锁,则无需去关闭锁
    //如果不能获取锁,则直接做其他事情
}

具体实现要分情况实现:

1.在参数时间内成功获取锁:

package Lock;

import java.util.concurrent.TimeUnit;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

/**
 * @author jc
 *
 */
public class TryLock {
	//实例化Lock对象
	Lock lock = new ReentrantLock();

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		//实例化本类对象,目的是调用runThread方法
		TryLock tl = new TryLock();
		//匿名对象创建线程1,并重写run方法,启动线程
		new Thread(){
			public void run(){
				
				tl.runThread(Thread.currentThread());
			}
		}.start();
		//匿名对象创建线程2,并重写run方法,启动线程
		new Thread(){
			public void run(){
				
				tl.runThread(Thread.currentThread());
			}
		}.start();
		
		
	}
	//线程共同调用方法
	public void runThread(Thread t){
		//lock对象调用trylock(long time , TimeUnit unit)方法尝试获取锁
		try {
			//注意,这个方法需要抛出中断异常
			if(lock.tryLock(5000L,TimeUnit.MILLISECONDS)){
				//获锁成功代码段
				System.out.println("线程"+t.getName()+"获取锁成功");
				try {
					//执行的代码
					Thread.sleep(3000);
				} catch (Exception e) {
					//异常处理内容,比如中断异常
				} finally {
					//获取锁成功之后,一定记住加finally并unlock()方法,释放锁
					System.out.println("线程"+t.getName()+"释放锁");
					lock.unlock();
				}
			}else{
				//获锁失败代码段
				//具体获取锁失败的回复响应
				System.out.println("线程"+t.getName()+"获取锁失败");
			}
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
	}
}
/**
 * output
 * 线程Thread-0获取锁成功
 * 线程Thread-0释放锁
 * 线程Thread-1获取锁成功
 * 线程Thread-1释放锁
 */

从运行结果可以看到,在等待时间内成功获取了锁。

2.在参数时间内未成功获取锁

package Lock;

import java.util.concurrent.TimeUnit;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

/**
 * @author jc
 *
 */
public class TryLock {
	//实例化Lock对象
	Lock lock = new ReentrantLock();

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		//实例化本类对象,目的是调用runThread方法
		TryLock tl = new TryLock();
		//匿名对象创建线程1,并重写run方法,启动线程
		new Thread(){
			public void run(){
				
				tl.runThread(Thread.currentThread());
			}
		}.start();
		//匿名对象创建线程2,并重写run方法,启动线程
		new Thread(){
			public void run(){
				
				tl.runThread(Thread.currentThread());
			}
		}.start();
		
		
	}
	//线程共同调用方法
	public void runThread(Thread t){
		//lock对象调用trylock(long time , TimeUnit unit)方法尝试获取锁
		try {
			//注意,这个方法需要抛出中断异常
			if(lock.tryLock(2000L,TimeUnit.MILLISECONDS)){
				//获锁成功代码段
				System.out.println("线程"+t.getName()+"获取锁成功");
				try {
					//执行的代码
					Thread.sleep(4000);
				} catch (Exception e) {
					//异常处理内容,比如中断异常
				} finally {
					//获取锁成功之后,一定记住加finally并unlock()方法,释放锁
					System.out.println("线程"+t.getName()+"释放锁");
					lock.unlock();
				}
			}else{
				//获锁失败代码段
				//具体获取锁失败的回复响应
				System.out.println("线程"+t.getName()+"获取锁失败");
			}
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
	}
}
/**
 * output
 * 线程Thread-0获取锁成功
 * 线程Thread-1获取锁失败
 * 线程Thread-0释放锁
 */

从运行结果可以看到,在参数时间内未过去锁,则立即退出尝试获取锁,去执行else内的代码块。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/181440.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 免费的dns_常用的dns有哪些

    免费的dns_常用的dns有哪些国内部分常用免费DNS服务整理(2021-09) 名称 首选地址 备选地址 114DNS 114.114.114.114 114.114.115.115 阿里DNS 223.5.5.5 223.6.6.6 百度DNS 180.76.76.76 ipv6地址:2400:da00::6666 腾讯DNS(DNSPod) 119.29.29.29 119.28.28.28 腾讯DNS(DNSPod) 182.254.

    2025年9月7日
    6
  • python最长回文子串动态规划_最长回文子串问题

    python最长回文子串动态规划_最长回文子串问题问题描述回文串是指aba、abba、cccbccc、aaaa这种左右对称的字符串。输入一个字符串Str,输出Str里最长回文子串的长度。方法一:暴力求解遍历每一个子串,再判断这个子串是不是回文串,最后判断这个串是不是最长的回文子串。遍历子串的复杂度是O(n^2),判断是不是回文串的复杂度是O(n),所以这个算法的复杂度是O(n^3)。方法二:动态规划法用一个二维的数组ai来表示从第i位到第j位的子…

    2022年6月1日
    41
  • Windows下 LaTeX安装教程 TeX Live 2021版[通俗易懂]

    Windows下 LaTeX安装教程 TeX Live 2021版[通俗易懂]latex版本众多,这里只介绍windows版本官方网站:TeXLive-TeXUsersGroup第一步,点击onDVD第二步:点击如图第三步:点击第四步:点击如下链接,等待下载完成第五步:双击或者右击Windows资源管理器第六步:点击安装,注意安装地址,建议不要放在C盘点击安装耐心等待。。。…

    2022年6月1日
    238
  • 《工具癖》从Github下载开源电子书

    《工具癖》从Github下载开源电子书

    2021年5月27日
    129
  • 【Android】Android游戏编程之从零开始[通俗易懂]

    【Android】Android游戏编程之从零开始[通俗易懂]《Android游戏编程之从零开始》主要系统地讲解了Android游戏开发,从最基础部分开始,让零基础的Android初学者也能快速学习和掌握Android游戏开发。《Android游戏编程之从零开始》一共8章,内容包括Android平台介绍与环境搭建、Hello,Android!项目剖析、游戏开发中常用的系统组件、游戏开发基础、游戏开发实战、游戏开发提高篇、Box2d物理引擎、物…

    2022年5月27日
    207
  • hypervisor kvm_docker vmware

    hypervisor kvm_docker vmwareLinuxhypervisor介绍荣涛2021年10月14日1.引言管理程序对操作系统所做的事情就像操作系统对进程所做的大致相同。它们为执行提供隔离的虚拟硬件平台,从而提供对底层机器的完全访问的错觉。但并非所有的虚拟机管理程序都是一样的,这是一件好事,因为Linux是关于灵活性和选择的。本文首先简要介绍虚拟化和管理程序,然后探讨几个基于Linux的管理程序。2.平台设备模拟平台虚拟化是关于在两个或多个操作系统之间共享一个平台,以便更有效地利用资源。但平台不仅仅意味着处理

    2022年9月22日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号