java 多线程理发师_GitHub - kriywu/SleepBarber: Java实现多理发师理发问题,线程并发...

本文主要是介绍java 多线程理发师_GitHub - kriywu/SleepBarber: Java实现多理发师理发问题,线程并发...,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SleepBarber

Java实现多理发师理发问题,线程并发

理发师问题描述:

一个理发店由一个有n个椅子的等候室和一个有一个理发椅的理发室组成。

如果有没有顾客来服务,理发师就去睡觉了。

如果顾客走进理发店和所有的椅子被占用了,然后顾客离开了商店。

如果理发师很忙,但是椅子是可用的,那么顾客坐在一张免费的椅子上。

如果理发师睡着了,顾客就会叫醒理发师。

这是课本上的理发师问题,对于这个问题的解答网上有很多解法,可参考:CSDN 进程(线程)间同步互斥问题

(三) 熟睡的理发师问题

加强版的问题描述:

一个理发店由一个有n个椅子的等候室和一个有m理发椅的理发室组成。

如果有没有顾客可以服务,所有的理发师都去睡觉。

如果顾客走进理发店椅子被占用了,然后顾客离开了商店。

如果所有的理发师都很忙,但是椅子是可用的,然后顾客坐在一张免费的椅子上。

如果理发师睡着了,顾客就会醒过来的理发师。

问题流程分析:

让我们先来看看一个理发师的场景再现:

3c3a439ae1da0db9b570d8c812ded6a9.png

阳关明媚的早上,商店开门。店里面空空如也,理发师伸了个懒腰,睡回笼觉去了。

一位顾客来了,发现理发师都在睡觉,走到理发师面前,拍醒了理发师。

理发师醒了之后,十分抱歉,赶快给顾客理发。

理发完成,理发师告诉顾客:发理好了。

客户答到:好的!转身离开理发店。

理发师呼叫一下一个顾客

若发现理发店恢复了空空如也的状态,就继续去睡觉了

若在还有顾客在椅子上等待,理发师就去唤醒椅子上睡觉的顾客。

+ 顾客随理发师坐到理发椅上,等待理发师理发完成

+ 重复步骤4

....

当有多个理发师的时候会怎么样呢。言语有点难以描述了,可以看作多个单理发师的理发师店共享等待椅子队列。每个理发师,访问相同的等待椅子,但是,理发的时候互不影响。

技术需求

为了完成这个实验,我查看了《Java核心技术 卷 I》并发内容。在Java中对于多线程同步的支持有很多方案。除了简单的锁对象(Class Lock),和条件对象(Class Condition)搭配使用之外,还有Synchronization关键字用来保护一个代码片段,避免多个线程同时修改临界区内容,也可以使用阻塞队列等。我感觉锁和条件对象比较适合这一题的解答。

锁和条件对象的的使用:

private Lock lock=new ReentrantLock();

lock.lick();//获取这个锁,如果这个锁被另外一个线程拥有则阻塞

lock.unlock();//释放锁

private Condition condition = lock.newCondition();

condition.await();//阻塞当前线程

condition.signalAll();//释放拥有因为condition.await();的线程

condition.siginal();//在阻塞队列中随机释放一个线程

那么问题来了,我们需要那些锁呢?我们再看一个理发师的情况,一个理发师锁,一个用户锁,一个互斥锁就行了。

理发师在没有顾客的时候,调用自己的Condition.await()。

用户来的时候调用Barber.Condition.singalAll();并调用 自己的Condition.await()即可;

理发师线程释放之后进一步向前推进,直达下一次和客户沟通的时候,挂起自己,唤醒客户线程。

重复上述就可完成理发师线程和用户线程的沟通了。

那么多个理发师的时候,每个理发师都有自己的用户,理发师和用户之间的信息交换是1对1的,那么也就是说每个理发师都有自己的锁和条件对象,以供顾客调用。与此同时,每个顾客应该也有自己的锁和对象让理发师调用。毕竟理发师们只不过是共享了用户队列。

这篇关于java 多线程理发师_GitHub - kriywu/SleepBarber: Java实现多理发师理发问题,线程并发...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用FileChannel实现文件的复制和移动方式

《使用FileChannel实现文件的复制和移动方式》:本文主要介绍使用FileChannel实现文件的复制和移动方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录使用 FileChannel 实现文件复制代码解释使用 FileChannel 实现文件移动代码解释

Spring实现Bean的初始化和销毁的方式

《Spring实现Bean的初始化和销毁的方式》:本文主要介绍Spring实现Bean的初始化和销毁的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Bean的初始化二、Bean的销毁总结在前面的章节当中介绍完毕了ApplicationContext,也就

Java的"伪泛型"变"真泛型"后对性能的影响

《Java的伪泛型变真泛型后对性能的影响》泛型擦除本质上就是擦除与泛型相关的一切信息,例如参数化类型、类型变量等,Javac还将在需要时进行类型检查及强制类型转换,甚至在必要时会合成桥方法,这篇文章主... 目录1、真假泛型2、性能影响泛型存在于Java源代码中,在编译为字节码文件之前都会进行泛型擦除(ty

Java中的getBytes()方法使用详解

《Java中的getBytes()方法使用详解》:本文主要介绍Java中getBytes()方法使用的相关资料,getBytes()方法有多个重载形式,可以根据需要指定字符集来进行转换,文中通过代... 目录前言一、常见重载形式二、示例代码三、getBytes(Charset charset)和getByt

Java使用Stream流的Lambda语法进行List转Map的操作方式

《Java使用Stream流的Lambda语法进行List转Map的操作方式》:本文主要介绍Java使用Stream流的Lambda语法进行List转Map的操作方式,具有很好的参考价值,希望对大... 目录背景Stream流的Lambda语法应用实例1、定义要操作的UserDto2、ListChina编程转成M

Spring框架中@Lazy延迟加载原理和使用详解

《Spring框架中@Lazy延迟加载原理和使用详解》:本文主要介绍Spring框架中@Lazy延迟加载原理和使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、@Lazy延迟加载原理1.延迟加载原理1.1 @Lazy三种配置方法1.2 @Component

使用easy connect之后,maven无法使用,原来需要配置-Djava.net.preferIPv4Stack=true问题

《使用easyconnect之后,maven无法使用,原来需要配置-Djava.net.preferIPv4Stack=true问题》:本文主要介绍使用easyconnect之后,maven无法... 目录使用easGWowCy connect之后,maven无法使用,原来需要配置-DJava.net.pr

idea报错java: 非法字符: ‘\ufeff‘的解决步骤以及说明

《idea报错java:非法字符:‘ufeff‘的解决步骤以及说明》:本文主要介绍idea报错java:非法字符:ufeff的解决步骤以及说明,文章详细解释了为什么在Java中会出现uf... 目录BOM是什么?1. BOM的作用2. 为什么会出现 \ufeff 错误?3. 如何解决 \ufeff 问题?最

python+OpenCV反投影图像的实现示例详解

《python+OpenCV反投影图像的实现示例详解》:本文主要介绍python+OpenCV反投影图像的实现示例详解,本文通过实例代码图文并茂的形式给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前言二、什么是反投影图像三、反投影图像的概念四、反向投影的工作原理一、利用反向投影backproj

使用Java编写一个字符脱敏工具类

《使用Java编写一个字符脱敏工具类》这篇文章主要为大家详细介绍了如何使用Java编写一个字符脱敏工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、字符脱敏工具类2、测试工具类3、测试结果1、字符脱敏工具类import lombok.extern.slf4j.Slf4j