线程安全和线程同步

本文详细探讨了C#中的线程同步机制,包括线程锁Lock、信号同步WaitHandle(如AutoResetEvent、Semaphore和Mutex)、以及Interlocked原子操作。讲解了这些技术如何确保线程安全,避免竞态条件,并举例说明在实际编程中的应用。
摘要由CSDN通过智能技术生成

一. 关于线程安全和线程同步

线程同步:

进程/线程同步就是并发进程/线程在⼀些关键点上可能需要互相等待与互通消息。
即当有一个线程在对内存进行操作时,其他线程都不可以对这个内存地址进行操作,处于等待状态,直到该线程完成操作, 其他线程才能对该内存地址进行操作。

线程安全:

一个类或者程序所提供的接口对于线程来说是原子操作或者多个线程之间的切换不会导致该接口的执行结果存在二义性,也就是说我们不用考虑同步的问题。


二. C#中的线程同步技术:

2.1. 线程锁Lock

线程锁的原理,就是锁住一个资源,使得应用程序在此刻只有一个线程访问该资源。
锁定使用关键字lock和类型Monitor,两者没有本质区别,前者是后者的语法糖。

2.2. 信号同步WaitHandle

信号同步机制中涉及的类型都继承自抽象类WaitHandle
EventWaitHandle(子类为AutoResetEvent、ManualResetEvent)、Semaphore以及Mutex都继承自WaitHandle,所以他们底层的原理是一致的,维护的都是一个系统内核句柄。

EventWaitHandle(AutoResetEvent、ManualResetEvent):

维护一个由内核产生的布尔类型对象(称为阻滞状态),如果其值为false,那么在它上面的线程就阻塞。可以调用类型的Set方法将其值设置为true,接触阻塞。
AutoResetEvent、ManualResetEvent区别:前者在发送信号完毕后(即调用Set方法后),会自动将阻滞状态重置为false,而后者需要手动进行设置。

Semaphore:

维护一个内核产生的整型变量,如果其值为0,则在它什么的线程就阻塞,如果其值大于0,则解除阻塞,同时,每解除一个线程阻塞,其值就减1。

Mutex:

EventWaitHandle和Semaphore提供的都是单应用程序域内的线程同步功能,而Mutex提供跨应用程序域阻塞和解除阻塞线程的能力。

2.3. InterLocked原子操作

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值