首页 > 其他分享 >线程同步机制3(Lock)

线程同步机制3(Lock)

时间:2022-12-18 10:44:56浏览次数:29  
标签:同步 Lock ReentrantLock unlock 线程 lock ticket

Lock锁

Java5开始,可以使用Java.util.concurrent.locks.Lock 接口
显示定义同步锁对象,实现同步机制,主要实现类是ReentrantLock类。
可使用ReentrantLock类显示加锁和释放锁。达到synchronized的效果。

Lock实现提供比使用synchronized方法和语句可以获得更广泛,更灵活的锁定操作
如:lock.lock(); lock.unlock();

import java.util.concurrent.locks.ReentrantLock;

public class SellTicket implements Runnable {

int ticket=100;

//创建锁对象(使用Lock对象)
ReentrantLock lock=new ReentrantLock();

@Override
public void run() {
    while (true){
        lock.lock();        //获取资源并且加锁
        if (ticket>0){
            
System.out.println(Thread.currentThread().getName()+"正在卖第"+ticket+"张票");
            ticket--;
            try {
                Thread.sleep(100);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }finally {
                //不管怎样,都会执行
                lock.unlock();
            }
        }else {
            //如果是最后一张票,那么让该线程释放锁
            lock.unlock();
            break;
        }
    }
}
}

标签:同步,Lock,ReentrantLock,unlock,线程,lock,ticket
From: https://www.cnblogs.com/Sco-/p/16990078.html

相关文章

  • 线程同步机制2(死锁)
    死锁1什么情况下会产生死锁①.资源有限②.同步嵌套2定义:一般指是同步代码块的嵌套引起的,两个线程各自拿着自己的对象锁不放,造成一个一直僵持的局势  两个线......
  • 线程通信
    一概述:多个线程执行不同任务获取同一个资源,此时需要线程通信来帮助解决线程之间对同一个变量的使用或操作。(避免对同一共享变量的争夺,导致死锁)于是我们引出了等待唤醒机......
  • abp vnext blog模块用户信息同步 源码解析
    先看一下Volo.Blogging.Domain引用的关于用户的项目只有Volo.Abp.Users.Domain,再看BlogUser定义:publicclassBlogUser:AggregateRoot<Guid>,IUser,IUpdateUserD......
  • ollydbg中加载的DLL基地址确定 IDA里IDA:Edit->segments->Rebase program去设置同步
    ollydbg在工具栏E里点击,找到加载的DLL,可以看到基地址,例如下面的就是6CBE0000,IDA里IDA:Edit->segments->Rebaseprogram去设置同步即可!      好了下面是一些......
  • TIDB-DM数据迁移第二部(创建同步任务)
    文档:https://docs.pingcap.com/zh/tidb/stable/quick-start-create-source实验环境源(MySQL):10.255.8.122:3306目标(TiDB):172.16.1.10:3306全量加增量模式,忽略test......
  • redis之单线程
    一、redis为何是单线程官方给出的答案:因为Redis是基于内存的操作,CPU不会成为Redis的瓶颈,而最有可能是机器内存的大小或者网络带宽。既然单线程容易实现,而且CPU不......
  • ThreadPoolExecutor创建线程池启动项目报错问题
    ThreadPoolExecutor创建线程,如下代码:ThreadPoolExecutorthreadPoolExecutor=newThreadPoolExecutor(Runtime.getRuntime().availableProcessors()+1,20,......
  • 线程常用方法
    线程常用方法介绍1、方法概述方法说明static功能说明注意start()启动一个新线程,在新的线程运行run方法中的代码start方法只是让线程进入就绪,里面代码不一......
  • Python之threading: 带你了解多线程的强大威力!
    前言什么是多线程多线程是指在一个程序中同时创建和使用多个执行流(thread)来执行不同的任务。这样多个任务就可以同时进行,从而提高程序的执行效率。在python使用多线......
  • 创建线程的4种方法
    线程创建方法1、继承Thread,重写run方法 privatestaticvoidone(){classTextendsThread{@Overridepublicvo......