Semaphore(信号量)
Semaphore
msdn介绍:
限制可同时访问某一资源或资源池的线程数。
命名空间: System.Threading
程序集: System(在 System.dll 中)
通俗理解:
1:宾馆开房 房间只能住3个人,现在来了5个人。
2:开门进去3个人 这个时候还有2个人只能在外面等待了。
3:如果出来一个人 剩下的2个进去其中1个。 同理房间还是3个人
后面如果继续来人。 如此往复
核心 总数3个人 。对应msdn 就是允许3个人同时访问 某一资源或资源池的线程数。
构造函数为initialCount和maximumCount,表示默认设置的信号量个数和最大信号量个数,
其实说到底,里面是采用计数器来来分配信号量,
当你WaitOne的时候,信号量自减,
当Release的时候,信号量自增,
然而当信号量为0的时候,后续的线程就不能拿到WaitOne了,所以必须等待先前的线程通过Release来释放。
代码:
namespace ConsoleApplication2
{
class Program
{
static Semaphore sh = new Semaphore(, ); static void Main(string[] args)
{
Thread t1 = new Thread(Run);
t1.Name = "t1"; Thread t2 = new Thread(Run);
t2.Name = "t2"; Thread t3 = new Thread(Run);
t3.Name = "t3"; Thread.Sleep(); t1.Start();
t2.Start(); Thread.Sleep();
t3.Start(); Console.Read();
} static void Run()
{
sh.WaitOne(); Console.WriteLine("大家好,我是{0}", Thread.CurrentThread.Name);
}
}
}
图:
t3 永远都出不来了 原因
static Semaphore sh = new Semaphore(2, 10);
sem.WaitOne(); 就是吧2-- 这里执行2次就变0了
我计数器是2 就是类似上面的房间只能3个人。
10是最大容量 现在进去了2个自然t3出不来了。
这个时候我们手动干预一下,
我们知道调用Release方法相当于自增一个信号量也可以加到maximunCount个信号量 即这里的10
代码:
namespace ConsoleApplication2
{
class Program
{
static Semaphore sh = new Semaphore(, ); static void Main(string[] args)
{
Thread t1 = new Thread(Run);
t1.Name = "t1"; Thread t2 = new Thread(Run);
t2.Name = "t2"; Thread t3 = new Thread(Run);
t3.Name = "t3"; Thread.Sleep(); t1.Start();
t2.Start();
t3.Start(); Thread.Sleep(); sh.Release(); Console.Read();
} static void Run()
{
sh.WaitOne(); if (Thread.CurrentThread.Name == "t3")
{
Console.WriteLine("我终于出来了 我是被sh.Release(10)解放的 我的名字是{0}", Thread.CurrentThread.Name);
}
else
{
Console.WriteLine("大家好,我是{0}", Thread.CurrentThread.Name);
}
}
}
}
Semaphore升级进程交互。
在VS对象浏览器中发现Semaphore是继承字WaitHandle,而WaitHandle封装了win32的一些同步机制,所以当我们给Semaphore命名的时候
就会在系统中可见
namespace System.Threading
{
// 摘要:
// 限制可同时访问某一资源或资源池的线程数。
[ComVisible(false)]
public sealed class Semaphore : WaitHandle
{
.........
}
}
把下面的代码copy一份,运行两个程序。
namespace ConsoleApplication2
{
class Program
{
static Semaphore sh = new Semaphore(, ,"tsp"); static void Main(string[] args)
{
Thread t1 = new Thread(Run);
t1.Name = "t1"; Thread t2 = new Thread(Run);
t2.Name = "t2"; t1.Start();
Thread.Sleep();
t2.Start(); Console.Read();
} static void Run()
{
sh.WaitOne(); Console.WriteLine("当前时间:{0} 大家好,我是{1}", DateTime.Now, Thread.CurrentThread.Name);
}
}
}
t2也出不来了。
Semaphore(信号量)的更多相关文章
- CountDownLatch 闭锁、FutureTask、Semaphore信号量、Barrier栅栏
同步工具类可以是任何一个对象.阻塞队列可以作为同步工具类,其他类型的同步工具类还包括信号量(Semaphore).栅栏(Barrier).以及闭锁(Latch). 所有的同步工具类都包含一些特定的结构 ...
- Java并发编程笔记之Semaphore信号量源码分析
JUC 中 Semaphore 的使用与原理分析,Semaphore 也是 Java 中的一个同步器,与 CountDownLatch 和 CycleBarrier 不同在于它内部的计数器是递增的,那 ...
- 互联网进行限流策略的Semaphore信号量使用
在Semaphore信号量非常适合高并发访问,新系统在上线之前,要对系统的访问量进行评估,当然这个值肯定不是随便拍拍脑袋就能想出来的,是经过以往的经验.数据.历年的访问量,已经推广力度进行一个合理的评 ...
- python网络编程--线程Semaphore(信号量)
一:Semaphore(信号量) 互斥锁 同时只允许一个线程更改数据,而Semaphore是同时允许一定数量的线程更改数据 ,比如厕所有3个坑,那最多只允许3个人上厕所,后面的人只能等里面有人出来了才 ...
- java并发之(4):Semaphore信号量、CounDownLatch计数锁存器和CyclicBarrier循环栅栏
简介 java.util.concurrent包是Java 5的一个重大改进,java.util.concurrent包提供了多种线程间同步和通信的机制,比如Executors, Queues, Ti ...
- 多线程锁:Mutex互斥体,Semaphore信号量,Monitor监视器,lock,原子操作InterLocked
Mutex类 “mutex”是术语“互相排斥(mutually exclusive)”的简写形式,也就是互斥量.互斥量跟临界区中提到的Monitor很相似,只有拥有互斥对象的线程才具有访问资源的权限, ...
- Python 中Semaphore 信号量对象、Event事件、Condition
Semaphore 信号量对象 信号量是一个更高级的锁机制.信号量内部有一个计数器而不像锁对象内部有锁标识,而且只有当占用信号量的线程数超过信号量时线程才阻塞.这允许了多个线程可以同时访问相同的代码区 ...
- 21.Semaphore信号量
Semaphore是一种基于计数的信号量.它可以设定一个阈值,基于此,多个线程竞争获取许可信号,做自己的申请后归还,超过阈值后,线程申请许可信号将会被阻塞.Semaphore可以用来构建一些对象池,资 ...
- java架构之路(多线程)JUC并发编程之Semaphore信号量、CountDownLatch、CyclicBarrier栅栏、Executors线程池
上期回顾: 上次博客我们主要说了我们juc并发包下面的ReetrantLock的一些简单使用和底层的原理,是如何实现公平锁.非公平锁的.内部的双向链表到底是什么意思,prev和next到底是什么,为什 ...
- Python 之并发编程之进程中(守护进程(daemon)、锁(Lock)、Semaphore(信号量))
五:守护进程 正常情况下,主进程默认等待子进程调用结束之后再结束守护进程在主进程所有代码执行完毕之后,自动终止kill -9 进程号 杀死进程.守护进程的语法:进程对象.daemon = True设置 ...
随机推荐
- Hadoop集群搭建
配置IP,修改主机名,关闭防火墙,配置SSH免密码登录
- CF451D Count Good Substrings (DP)
Codeforces Round #258 (Div. 2) Count Good Substrings D. Count Good Substrings time limit per test 2 ...
- CString
CString gray("Gray"); CString cat("Cat"); CString graycat = gray + cat; 与其用 sp ...
- Makefile-2
一.命令行参数 -n/--just-print/--dry-run/--recon 只显示命令,但不会执行命令,用于调试 makefile. -s/--slient/--quiet 禁止命令的显示 ...
- 连接到kali linux服务器上的MySQL服务器错误
前言:想把数据库什么的都放在虚拟机kali Linux里,但无奈出了好多错误. 首先:可以参照上一篇文章开启kali服务器端的远程连接功能,上一篇文章 然后:使用window端的sqlyog(MySQ ...
- Ubuntu10.04下安装Ns2的一系列错误及解决方案
安装之前改一下nam1.11下的agent.h文件73行 Null改为0 第一个错误: xxx configuration: Syntax error: Unterminated quoted str ...
- Ubuntu/Windows下利用“HIDAPI”库函数实现与Hid类USB设备通信
一.背景: 最近在做的一个项目需要使用USB传递数据,对USB理解不是很深,USB的系统驱动编写则更是天方 夜谭,因此将设备配置成HID类设备成为了首选.其最大的好处在于,LINUX/Windows系 ...
- Jquery中的事件和动画
在学习Jquery中的过程中我们绝大部分都用到了事件的操作,也可以说事件是Jquery中必不可少的一部分,我们常见的一些事件有单击事件,鼠标事件,键盘事件等等.在Jquery中的学习中为了能使让页面以 ...
- SSH-keygen参数说明
以防网址丢失发,复制备份.复制来源ssh-keygen参数说明 ssh-keygen - 生成.管理和转换认证密钥 ssh-keygen [-q] [-b bits] -t type [-N ...
- 数据源和JNDI的关系:
DataSource对象是由Tomcat提供的,因此不能在程序中采用创建一个实例的方式来生产DataSource对象,而需要采用Java的另一个技术JNDI,来获得DataSource对象的引用. T ...