WaitHandle——使用Semaphore

简介:     semaphore也继承自waithandle,它用于锁机制,与Mutex不同的是,它允许指定数量的线程同时访问资源,在线程超过数量以后,则进行排队等待,直到之前的线程退出。     Semaphore很适合应用于web服务器这样的高并发场景,可以限制对资源访问的线程数。



    semaphore也继承自waithandle,它用于锁机制,与Mutex不同的是,它允许指定数量的线程同时访问资源,在线程超过数量以后,则进行排队等待,直到之前的线程退出。

    Semaphore很适合应用于web服务器这样的高并发场景,可以限制对资源访问的线程数。


    Monitor与monitor都有一个锁持有者,而semaphore则不需要,因此通常将sempahore声明为静态的。


 

   来看下面的示例:


namespace 使用Semaphore
{
    class Program
    {

         //第一个参数指定当前运行多少条线程进入,第二个参数表示 允许多少个线程同时进入
        static Semaphore sem = new Semaphore(2, 2); 


        static void Main(string[] args)
        {
            for (int i = 1; i <=4; i++)
            {
                new Thread (ThreadEntry).Start (i);


            }
        } 

        static void ThreadEntry(object id) {

            Console.WriteLine("thread {0} wants to get in",id);
            sem.WaitOne();  //在调用waitone方法时,如果有空位,则占位;如果没有,则等待;
            Console.WriteLine("thread {0} gets in",id );
            Thread.Sleep(100);
            Console.WriteLine("thread {0} is leaving",id );
            sem.Release();  //释放一个空位;

        
        }
    }
}


调用结果:



 



     设想下,如果有一个抢票的页面,所有人同一时刻并发访问,可以用此对象设置好并发的人数和同时可以有多少人进入等待状态。其他人可以排到一个队列中,如果队列过长的话,会造成服务器内存消耗过多,这时,可以采用分布式的方法,把队列分配到不同的主机上,减轻服务器压力。


   以上设想还未在实践中使用过,但是学习了两天如何处理高并发问题,这也算是理出来的一个思路吧。






目录
相关文章
|
4月前
|
Java
JAVA并发编程系列(7)Semaphore信号量剖析
腾讯T2面试,要求在3分钟内用不超过20行代码模拟地铁安检进站过程。题目设定10个安检口,100人排队,每人安检需5秒。实际中,这种题目主要考察并发编程能力,特别是多个线程如何共享有限资源。今天我们使用信号量(Semaphore)实现,限制同时进站的人数,并通过信号量控制排队和进站流程。并详细剖析信号量核心原理和源码。
Semaphore 使用详解
本文主要对Semaphore 的相关知识点进行了介绍和讲解
133 0
|
8月前
|
数据库连接
认识 Semaphore
认识 Semaphore
55 0
|
Java 数据库连接 API
【JUC】信号量Semaphore详解
【JUC】信号量Semaphore详解
187 0
【JUC】信号量Semaphore详解
|
监控 数据库连接
呵,Semaphore ,就这?(一)
那么本篇文章我们继续来和你聊聊并发工具类的第二篇文章 --- Semaphore 。
129 0
呵,Semaphore ,就这?(一)
|
Java
呵,Semaphore ,就这?(二)
那么本篇文章我们继续来和你聊聊并发工具类的第二篇文章 --- Semaphore 。
129 0
呵,Semaphore ,就这?(二)
Semaphore 信号量源码分析
Semaphore 信号量源码分析
Semaphore 信号量源码分析
|
Java
Java并发编程之Semaphore信号量
Java并发编程之Semaphore信号量
161 0
Java并发编程之Semaphore信号量
|
Java 开发工具
信号量Semaphore及模型
信号量Semaphore
137 0
Semaphore信号量
Semaphore 可以用来限制或管理数量有限资源的使用情况 - 信号量的作用是用来维护一个“许可证”,的计数,线程可以获取 许可证,那信号量剩余许可证就减一,线程也可以是否一个许可证,那剩余的许可证就加一,当信号量拥有的许可证为0时,那么下一个线程想获得许可证,就要进行等待,直到另外线程释放许可证
285 0
Semaphore信号量