自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

我們一起聊聊信號量對象沒有所有者

開發(fā) 前端
如果線程在設法釋放信號量之前退出(或崩潰),則信號量計數(shù)器不會自動還原。相較于互斥對象,如果所有者線程在持有互斥對象時終止,則釋放互斥對象。因此,對于這種使用模式,使用互斥對象更加合適一些。

相較于互斥對象(Mutex)和臨界區(qū)對象(Critical Section) ,信號量沒有所有者,它們只有計數(shù)。

ReleaseSemaphore 函數(shù)將會以指定的數(shù)量增加對應信號量對象的計數(shù)。 (增加計數(shù)這個動作,可能會釋放正在等待的線程)但是釋放信號量的線程不必與最初聲明它的線程相同。這與互斥對象和臨界區(qū)對象不同,后者要求聲明線程也是釋放線程。

有些人以類似互斥對象的方式使用信號量: 他們創(chuàng)建一個初始計數(shù)為 1 的信號量,并像這樣使用它,如下面代碼所示:

WaitForSingleObject(hSemaphore, INFINITE);
… do stuff ..
ReleaseSemaphore(hSemaphore, 1, NULL);

如果線程在設法釋放信號量之前退出(或崩潰),則信號量計數(shù)器不會自動還原。相較于互斥對象,如果所有者線程在持有互斥對象時終止,則釋放互斥對象。因此,對于這種使用模式,使用互斥對象更加合適一些。

如果資源的概念所有權可以跨線程,則信號量非常有用。我們來看下圖:

此技巧不適用于互斥對象或臨界區(qū)對象,因為互斥對象和臨界區(qū)對象具有所有者,并且只有所有者才能釋放互斥對象或臨界區(qū)對象。

請注意,如果 KeepWorking 函數(shù)退出并忘記釋放信號量,則計數(shù)器不會自動恢復。操作系統(tǒng)不知道信號量”屬于”該工作項。

信號量的另一種常見用法模式與資源保護模式相反:它是資源生成模式。在此模型中,信號量計數(shù)通常為零,但在有工作要完成時遞增。

請注意,在這種情況下,甚至沒有信號量的概念”所有者”,除非你將工作項本身(位于工作列表數(shù)據(jù)結構上的某處)視為所有者。如果 ProcessWork 線程退出,則不希望自動釋放信號量,那會破壞掉內部計數(shù)。在這種情況下,信號量是合適的對象。

(生產者/使用者信號量的更高性能版本是 I/O 完成端口。)

總結

既然提到了所謂的高性能版本,我想原作者所表達的意思是:對于爾等 C++ 工人來說,平常使用無妨,但是如果是性能攸關的代碼,頻繁地切換內核上下文所帶來的性能開銷,不可小視。

責任編輯:武曉燕 來源: 今日頭條
相關推薦

2023-05-30 07:52:38

信號量版本C++

2020-11-05 09:59:24

Linux內核信號量

2024-06-12 09:52:00

2023-08-04 08:20:56

DockerfileDocker工具

2022-05-24 08:21:16

數(shù)據(jù)安全API

2023-08-10 08:28:46

網絡編程通信

2023-09-10 21:42:31

2023-06-30 08:18:51

敏捷開發(fā)模式

2021-08-27 07:06:10

IOJava抽象

2024-02-20 21:34:16

循環(huán)GolangGo

2021-09-07 07:53:42

Semaphore 信號量源碼

2025-03-05 08:02:45

2022-02-23 08:41:58

NATIPv4IPv6

2022-09-22 08:06:29

計算機平板微信

2024-07-26 09:47:28

2021-08-12 07:49:24

mysql

2023-03-26 23:47:32

Go內存模型

2024-11-28 09:57:50

C#事件發(fā)布器

2022-10-08 00:00:05

SQL機制結構

2023-07-24 09:41:08

自動駕駛技術交通
點贊
收藏

51CTO技術棧公眾號