」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 生產者/消費者

生產者/消費者

發佈於2024-07-31
瀏覽:932

定義

我們考慮兩個流程,分別稱為「生產者」和「消費者」。生產者是一個循環過程,每次循環都會產生一定部分的訊息,這些訊息必須由消費者處理。消費者也是一個循環過程,每次它經歷它的週期時,它都可以處理下一個訊息,因為它是由生產者產生的。計算過程給出了一個簡單的例子,該計算過程產生由穿孔卡打孔的穿孔卡的「資訊部分」圖像,穿孔卡扮演消費者的角色。 [1]

Producer/Consumer (Produtor/Consumidor)

解釋

生產者建立專案並將其儲存在資料結構中,而消費者從該結構中刪除項目並處理它們。

如果消費大於生產,則緩衝區(資料結構)清空,消費者沒有什麼可消費的
如果消耗量小於生產量,則緩衝區已滿,生產者無法增加更多項目。這是一個經典問題,稱為有限緩衝區

問題的情境化

假設我們有一個生產者在緩衝區中發布一封電子郵件,以及一個消費者使用緩衝區中的電子郵件並顯示一條訊息,說明已使用所提供的電子郵件的新訪問密碼發送了一封電子郵件。 ]

去實施

包主 進口 ( “FMMT” “你” “strcon” “同步” “團隊” ) 類型緩衝區結構 { 項目[]字串 mu同步互斥體 } func (buff *buffer) add(項目字串) { buff.mu.Lock() 延遲 buff.mu.Unlock() if len(buff.items) package main import ( "fmt" "os" "strconv" "sync" "time" ) type buffer struct { items []string mu sync.Mutex } func (buff *buffer) add(item string) { buff.mu.Lock() defer buff.mu.Unlock() if len(buff.items) 解釋實施

    首先,我們建立一個名為
  • buffer 的結構,其中包含一個名為items 的字串陣列和一個名為mu 的類似互斥體的控制機制,用於管理並發存取。
  • 我們有兩個函數:一個稱為add,它基本上將一個項目添加到緩衝區中,只要有可用空間,因為緩衝區容量只有5 個項目;另一個get 調用,如果緩衝區中有項目,則傳回第一個元素並從緩衝區中刪除該元素。
  • Producer 基本上從循環中獲取索引,並將其連接成一個名為str 的字串,其中包含索引和虛擬電子郵件域,並將其添加到緩衝區。新增了時間間隔來模擬延遲。
  • 消費者從緩衝區請求一個項目(如果它至少有一個項目)。然後,消費者在螢幕上顯示一條訊息,通知已發送一封電子郵件,其中包含緩衝區中發布的項目的新存取密碼。

程式碼連結: https://github.com/jcelsocosta/race_condition/blob/main/ Producerconsumer/buffer/ Producerconsumer.go

參考

    https://www.cs.utexas.edu/~EWD/transcriptions/EWD01xx/EWD123.html#4.1。通用信號量的典型用途。
參考書目

https://www.cin.ufpe.br/~cagf/if677/2015-2/slides/08_Concorrencia (Jorge).pdf

版本聲明 本文轉載於:https://dev.to/celso/producerconsumer-produtorconsumidor-1jok?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 如何克服PHP的功能重新定義限制?
    如何克服PHP的功能重新定義限制?
    克服PHP的函數重新定義限制在PHP中,多次定義一個相同名稱的函數是一個no-no。嘗試這樣做,如提供的代碼段所示,將導致可怕的“不能重新列出”錯誤。 但是,PHP工具腰帶中有一個隱藏的寶石:runkit擴展。它使您能夠靈活地重新定義函數。 runkit_function_renction_...
    程式設計 發佈於2025-03-25
  • 如何將MySQL數據庫添加到Visual Studio 2012中的數據源對話框中?
    如何將MySQL數據庫添加到Visual Studio 2012中的數據源對話框中?
    在Visual Studio 2012 儘管已安裝了MySQL Connector v.6.5.4,但無法將MySQL數據庫添加到實體框架的“ DataSource對話框”中。為了解決這一問題,至關重要的是要了解MySQL連接器v.6.5.5及以後的6.6.x版本將提供MySQL的官方Visual...
    程式設計 發佈於2025-03-25
  • 如何從Google API中檢索最新的jQuery庫?
    如何從Google API中檢索最新的jQuery庫?
    從Google APIS 問題中提供的jQuery URL是版本1.2.6。對於檢索最新版本,以前有一種使用特定版本編號的替代方法,它是使用以下語法:獲取最新版本:未壓縮)While these legacy URLs still remain in use, it is recommended ...
    程式設計 發佈於2025-03-25
  • 如何使用組在MySQL中旋轉數據?
    如何使用組在MySQL中旋轉數據?
    在關係數據庫中使用mySQL組使用mySQL組進行查詢結果,在關係數據庫中使用MySQL組,轉移數據的數據是指重新排列的行和列的重排以增強數據可視化。在這裡,我們面對一個共同的挑戰:使用組的組將數據從基於行的基於列的轉換為基於列。 Let's consider the following ...
    程式設計 發佈於2025-03-25
  • 大批
    大批
    [2 數組是對象,因此它們在JS中也具有方法。 切片(開始):在新數組中提取部分數組,而無需突變原始數組。 令ARR = ['a','b','c','d','e']; // USECASE:提取直到索引作...
    程式設計 發佈於2025-03-25
  • 如何在php中使用捲髮發送原始帖子請求?
    如何在php中使用捲髮發送原始帖子請求?
    如何使用php 創建請求來發送原始帖子請求,開始使用curl_init()開始初始化curl session。然後,配置以下選項: curlopt_url:請求 [要發送的原始數據指定內容類型,為原始的帖子請求指定身體的內容類型很重要。在這種情況下,它是文本/平原。要執行此操作,請使用包含以下標頭...
    程式設計 發佈於2025-03-25
  • 在解散期間,如何處理動態JSON字段類型?
    在解散期間,如何處理動態JSON字段類型?
    在GO 要解決此問題,可以採用一種使用接口類型的類型 - 動態方法。考慮以下JSON數據: { “ mykey”:[[ {obj1}, {obj2} 這是給出的 } [2 mykey []接口{}`json:“ mykey”` } mykey slice元素將被...
    程式設計 發佈於2025-03-25
  • Java是否允許多種返回類型:仔細研究通用方法?
    Java是否允許多種返回類型:仔細研究通用方法?
    在Java中的多個返回類型:一種誤解類型:在Java編程中揭示,在Java編程中,Peculiar方法簽名可能會出現,可能會出現,使開發人員陷入困境,使開發人員陷入困境。 getResult(string s); ,其中foo是自定義類。該方法聲明似乎擁有兩種返回類型:列表和E。但這確實是如此嗎...
    程式設計 發佈於2025-03-25
  • 我可以將加密從McRypt遷移到OpenSSL,並使用OpenSSL遷移MCRYPT加密數據?
    我可以將加密從McRypt遷移到OpenSSL,並使用OpenSSL遷移MCRYPT加密數據?
    將我的加密庫從mcrypt升級到openssl 問題:是否可以將我的加密庫從McRypt升級到OpenSSL?如果是這樣,如何? 答案:是的,可以將您的Encryption庫從McRypt升級到OpenSSL。 可以使用openssl。 附加說明: [openssl_decrypt()函數要求...
    程式設計 發佈於2025-03-25
  • 克服NeoApps.ai的REST API挑戰
    克服NeoApps.ai的REST API挑戰
    使用標準實踐開發REST API是至關重要的,但通常具有挑戰性。從確保一致的設計和確保身份驗證到管理可擴展性和錯誤處理,開發人員面臨需要時間和專業知識的障礙。 REST API開發中的共同挑戰 一致的標準:跨端點保持統一性。 :在不斷發展的API時管理向後兼容。 身份驗證和安全性:安...
    程式設計 發佈於2025-03-25
  • PHP陣列鍵值異常:了解07和08的好奇情況
    PHP陣列鍵值異常:了解07和08的好奇情況
    PHP數組鍵值問題,使用07&08 在給定數月的數組中,鍵值07和08呈現令人困惑的行為時,就會出現一個不尋常的問題。運行print_r($月)返回意外結果:鍵“ 07”丟失,而鍵“ 08”分配給了9月的值。 此問題源於PHP對領先零的解釋。當一個數字帶有0(例如07或08)的前綴時,PHP將...
    程式設計 發佈於2025-03-25
  • 為什麼使用Firefox後退按鈕時JavaScript執行停止?
    為什麼使用Firefox後退按鈕時JavaScript執行停止?
    導航歷史記錄問題:JavaScript使用Firefox Back Back 此行為是由瀏覽器緩存JavaScript資源引起的。要解決此問題並確保在後續頁面訪問中執行腳本,Firefox用戶應設置一個空功能。 警報'); }; alert('inline Alert')...
    程式設計 發佈於2025-03-25
  • 在程序退出之前,我需要在C ++中明確刪除堆的堆分配嗎?
    在程序退出之前,我需要在C ++中明確刪除堆的堆分配嗎?
    在C中的顯式刪除 在C中的動態內存分配時,開發人員通常會想知道是否有必要在heap-procal extrable exit exit上進行手動調用“ delete”操作員,但開發人員通常會想知道是否需要手動調用“ delete”操作員。本文深入研究了這個主題。 在C主函數中,使用了動態分配變量(...
    程式設計 發佈於2025-03-25
  • 如何使用Java.net.urlConnection和Multipart/form-data編碼使用其他參數上傳文件?
    如何使用Java.net.urlConnection和Multipart/form-data編碼使用其他參數上傳文件?
    使用http request 上傳文件上傳到http server,同時也提交其他參數,java.net.net.urlconnection and Multipart/form-data Encoding是普遍的。 Here's a breakdown of the process:Mu...
    程式設計 發佈於2025-03-25
  • 程序終止時洩漏的內存會釋放嗎?
    程序終止時洩漏的內存會釋放嗎?
    embore洩漏和程序終端通常在編程中,必鬚根據需要分配和釋放資源。無法正確處理資源可能會導致內存洩漏,該程序不再引用分配的內存,而是被佔用。 當程序終止時,此洩漏的內存是否已釋放, 答案:對於最常見的操作系統,例如Windows,Linux和Solaris,此行為是正確的。但是,值得注意的是...
    程式設計 發佈於2025-03-25

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3