扫一扫
分享文章到微信
扫一扫
关注官方公众号
至顶头条
作者:Ruby中文社区 来源:Ruby中文社区 2007年9月14日
关键字:
Mutex有下列方法:
Mutex.new
生成新的互斥锁。
Mutex#lock
加锁。若已经处于加锁状态则会一直等待下去,直到解锁为止。
Mutex#unlock
解锁。若有其它等锁的线程则会让它们通过。
Mutex#synchronize
执行从获得锁到解锁全过程的迭代器。
Mutex#try_lock
获得锁。若已处于加锁状态,则返回false且不会挂起。
Queue
Queue就像一条读写数据的管道。提供数据的线程在一边写入数据,而读取数据的线程则在另一边读出数据。若Queue中没有可供读取的数据时,读取数据的线程会挂起等待数据的到来。
下面就是一个使用Queue的简单程序:
|
本程序中,一个线程读入一行之后,另一个线程就输出它。若把第3行改成数组,即“q=[]”后,线程间失去同步,则程序无法正确运作。
Queue有下列方法:
Queue.new
生成新的Queue。
Queue.empty?
若Queue为空则返回真。
Queue.push value
向Queue添加value。
Queue.pop [non_block]
从Queue中取出数据。若参数non_block被指定为非假值而且Queue为空时,则引发错误。其他情况下,若Queue为空时,读取数据的线程会被挂起直到有新数据加入。
例题
让我们来看一看在并行处理编程领域中非常有名的“哲学家就餐”问题。
“哲学家就餐”问题就是指在下述情况下,哲学家如何取得同步的问题。
有N位哲学家围坐在圆桌旁。圆桌中间放着盛满意大利面条的大盘子。另有N把叉子分别放在每位哲学家身旁。哲学家继续思考问题,若觉得饿就会拿起两旁的叉子就餐。吃完后就将叉子放回去。这些哲学家都是绅士,即使很饿也会等到两旁都有叉子可用之后才会就餐。
运行程序后会依次显示当前的状态。各个字符所代表的意义如下。
o:正在思考问题的哲学家
*:正在工作的哲学家
-:无人使用的叉子
|:正被使用的叉子
哲学家思考的时间和就餐的时间由随机数决定。
|
如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。
现场直击|2021世界人工智能大会
直击5G创新地带,就在2021MWC上海
5G已至 转型当时——服务提供商如何把握转型的绝佳时机
寻找自己的Flag
华为开发者大会2020(Cloud)- 科技行者