30.1 一个简单的混合锁

本文深入探讨了一种称为简单混合锁的同步机制,该机制结合了用户模式和内核模式的锁实现,以提高多线程环境下的性能。通过使用Interlocked和AutoResetEvent,简单混合锁能够有效地管理线程间的互斥访问。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

    /// <summary>
    /// 简单混合锁
    /// </summary>
    internal sealed class SimpleHybridLock : IDisposable
    {
        //由基元用户模式构造(Interlocked的方法)使用
        private int _waiters = 0;

        //AutoResetEvent 是基元内核模式构造
        private AutoResetEvent _waiterLock = new AutoResetEvent(false);

        public void Enter()
        {
            //指出这个线程想要获得锁
            if (Interlocked.Increment(ref _waiters) == 1)
                return;     //锁可自由使用,无竞争,直接返回

            //另一个线程拥有锁(发生竞争),使这个线程等待
            _waiterLock.WaitOne();      //这里产生较大的性能影响
            //WaitOne返回后,这个线程拿到锁了
        }

        public void Leave()
        {
            //这个线程准备释放锁
            if (Interlocked.Decrement(ref _waiters) == 0)
                return;     //没有其他线程正在等待,直接返回

            //有其他线程正在阻塞,唤醒其中一个
            _waiterLock.Set();      //这里产生较大的性能影响
        }

        public void Dispose()
        {
            _waiterLock.Dispose();
        }
    }

 

转载于:https://www.cnblogs.com/kikyoqiang/p/10226396.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值