生產者消費者模式 鎖優化

2021-08-09 02:54:28 字數 334 閱讀 8575

生產者消費者,這裡不多講, 這裡針對pool的鎖使用問題談一下個人的想法。

常規的生產者消費者模式,都是要加鎖的,加鎖寫,加鎖多,那麼針對資料量比較大的時候,其實是很影響效率的,下面這個方法,可以減少鎖的使用。

把pool分成多個buffer,選第乙個buffer裝資料(只寫不讀),當這個buffer裝滿,或取資料定時器到了的時候,就往下乙個buffer裡面寫資料,而這個buffer的資料再被全部取出來,這樣其實就是完全的讀寫分離,這樣也只有針對buffer組的取的時候會加鎖,且使用的頻率很低,不用每個資料單元都使用鎖。

這裡的timer,主要是針對最後的資料buffer沒有滿,但是還是應該要處理而設定。

生產者消費者 生產者與消費者模式

一 什麼是生產者與消費者模式 其實生產者與消費者模式就是乙個多執行緒併發協作的模式,在這個模式中呢,一部分執行緒被用於去生產資料,另一部分執行緒去處理資料,於是便有了形象的生產者與消費者了。而為了更好的優化生產者與消費者的關係,便設立乙個緩衝區,也就相當於乙個資料倉儲,當生產者生產資料時鎖住倉庫,不...

生產者 消費者模式

一 我哥們把資料存入redis快取區 生產者 二 我從緩衝器取資料,並作處理!消費者 詳細 如下 取訂單並判斷 redis new redis conn flag redis connect redis translate usefull host,redis translate usefull p...

生產者消費者模式

常見場景 某個模組負責產生資料,這些資料由另乙個模組來負責處理。產生資料的模組,就形象地稱為生產者 而處理資料的模組,就稱為消費者。該模式還需要有乙個緩衝區處於生產者和消費者之間,作為乙個中介。生產者把資料放入緩衝區,而消費者從緩衝區取出資料 緩衝區作用 1.解耦,生產者和消費者只依賴緩衝區,而不互...