本文向您展示了如何在Java中解析Semaphore。内容简洁易懂,一定会让你大放异彩。希望通过这篇文章的详细介绍,你能有所收获。
信号量(Semaphore)是由计算机科学家迪克斯特拉在1965年提出的。信号量在不同的操作系统中被广泛使用。在管理被提出之前,信号量是并发编程领域的霸主!几乎所有并发语言都支持信号量机制。
旗语也被翻译成信号灯,因为它的机制就像我们日常生活中的红绿灯。红绿灯是用来看车辆的流量,编程世界对应的线程能不能执行就看信号灯了!
信号量用于多线程互斥问题。与synchronized和Lock相比,它允许多个线程访问一个关键部分!比如各种池:数据库连接池、对象池等。这些池的要求是允许多个线程同时使用连接池。
Semaphore的模型可以概括为一个计数器、一个等待队列、三个方法。三个方法原子性分别是init()、down()、up();
Init():设置计数器的初始值。
Down():将计数器的值减少一。如果计数器的值减1后小于0,则阻塞当前线程;否则,继续执行。
Up():给计数器的值加一。如果计数器的值在加1后小于或等于0,则唤醒等待队列中的一个线程,并将其从等待队列中移除。(注意是小于等于0,不应该理解为大于等于0,因为大于等于0表明此时没有等待的线程,所以不会有唤醒这个操作。)
简单的理解就是Semaphore就是通过这三个方法来改变计数器,通过计数器的值来判断此时的线程是应该加入到等待队列中等待还是成功执行.
信号量模型也叫PV原语,即down和up操作最初叫P操作和V操作,也有人叫semWait和semSignal。
在JAVA中信号量模型是由 java.util.concurrent.Semaphore 的实现,并且down和up对应的实现方法是acquire和release,让我们看一个简单的使用例子。
如果您希望更多的线程进入临界区,请将Semaphore构造函数中的1更改为您想要的线程数。
可以理解为发放许可证。比如你想让三个线程同时进入临界区,那么构造器中的数字会被3填充,也就是说你拿到三个许可证,然后发放出去。获得许可证的人可以进入关键区域。当进入关键区域的线程完成后,它们将返回许可证,然后退出。
信号量中有三个类:同步、非同步和公平同步。
fairSync和fairsync类继承自Sync类,Sync类继承自AbstractQueuedSynchronizer抽象类,即Semaphore是依靠FairSync和FairSync实现的。
构造函数可用于指定它是公平锁还是不公平锁。Fair意味着该权限将只按照先到先得的顺序授予等待队列中的线程。不公平是指对于任何一个申请权限的线程,都是第一时间看有没有多余的权限,如果有,就给这个线程。
区别在于hasQueuedPredecessors()的存在与否。这个方法是确定当前线程是否是等待队列中的头节点,如果不是,就不分配。
以上内容就是如何在Java中解析Semaphore。你学到什么知识或技能了吗?如果你想学习更多的技能或丰富你的知识,请关注行业信息渠道。
内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/153159.html