Linux系统编程40:多线程之基于环形队列的生产者与消费者模型
文章目錄
- (1)什么是信號(hào)量
- (2)與信號(hào)量相關(guān)的操作
- (3)基于環(huán)形隊(duì)列的生產(chǎn)者與消費(fèi)者模型-信號(hào)量(單消費(fèi)者單生產(chǎn)者)
(1)什么是信號(hào)量
前面的敘述中,我們通過(guò)鎖保證了每次只有一個(gè)線程進(jìn)入臨界區(qū),但是臨界區(qū)資源很多也很大,每次只允許一個(gè)線程進(jìn)入往往會(huì)使效率很低。所以如果將臨界區(qū)劃分為多個(gè)獨(dú)立的區(qū)域,劃分為多少個(gè)區(qū)域就讓多少個(gè)線程進(jìn)入,,但是這樣就同時(shí)帶來(lái)了一個(gè)問(wèn)題——如果劃分為了5個(gè)區(qū)域,但是同時(shí)進(jìn)入了10個(gè)線程該怎么辦?所以這一點(diǎn)可以通過(guò)信號(hào)量解決。信號(hào)量可以理解為一個(gè)計(jì)數(shù)器,它用來(lái)描述臨界資源的有效個(gè)數(shù)
信號(hào)量由一個(gè)值和一個(gè)指針組成,指針指向等待該信號(hào)量的線程。信號(hào)量的值表示相應(yīng)資源的使用情況,比如如果S>=0表示資源夠用,如果執(zhí)行P操作表示請(qǐng)求分配一個(gè)資源,那么S就會(huì)減一;當(dāng)S<0時(shí)表示已經(jīng)沒(méi)有可用資源(此時(shí)S的絕對(duì)值表示等待該資源的線程數(shù))請(qǐng)求者必須等待其他線程釋放資源方可繼續(xù)運(yùn)行。如果執(zhí)行一個(gè)V操作就表示會(huì)釋放一個(gè)資源,所以S加一
(2)與信號(hào)量相關(guān)的操作
1:要使用信號(hào)量就需要?jiǎng)?chuàng)建一個(gè)sem_t類型變量
總結(jié)
以上是生活随笔為你收集整理的Linux系统编程40:多线程之基于环形队列的生产者与消费者模型的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 查看服务器信息命令
- 下一篇: 全球酒店详情查看API接口-基于极核数据