boost::io_service解讀
io_servie 實作了一個任務佇列,這裡的任務就是void(void)的函數。 Io_servie最常用的兩個介面是post和run,post向任務佇列中投遞任務,run是執行佇列中的任務,直到全部執行完畢,並且run可以被N個執行緒呼叫。 Io_service是完全線程安全的佇列。
boost::io_service解讀
asio是boost提供的一個c 非同步程式設計模型庫,其核心類別io_service,在多執行緒程式設計裡面提供了任務佇列和任務分發功能,在socket 、io程式設計裡主要作為一個事件磁碟機(完成連接埠、select、poll、epoll等)。
佇列模型
每個io_service都一個公有任務佇列,和多個私有任務佇列,公有佇列由各個執行緒共用,私有佇列則是每個執行緒獨享一個。
io_service的任務執行流程大致如下:
#呼叫run方法,進入主loop;
判斷公有佇列是否為空,不為空則取出任務並執行,當任務數大於1時同時喚醒其他空閒執行緒;
任務執行結束,把各個執行緒的私有隊伍裡面的任務移動到公有任務佇列裡面;
觸發reactor,linux下面一般是epoll,當有事件時,把對應的事件的任務放到私有隊列裡。
當佇列為空時,把目前執行緒加到空閒執行緒佇列裡面,同時進入wait狀態,等待其他執行緒的喚醒(task_operation)。
當使用者呼叫post時,任務是直接投遞到公有佇列op_queue裡面。
執行緒池模型
常用的執行緒池模型有兩種:
一種是多個執行緒共用一個任務佇列,使用者把任務投遞到該任務佇列中,其他執行緒競爭從該佇列中取得任務執行。結合boost::thread,在多個執行緒裡面呼叫run方法,即可實作該執行緒池:
using namespace boost; using namespace boost::asio; io_service ios; int thread_num = 10; thread *t[thread_num] = {0}; // 创建线程池 for(int i = 0; i < thread_num; ++i) { t[i] = new thread(bind(&io_service::run, &ios)); } // 向任务队列中投递任务,该任务将随机由一个调用run方法的线程执行 ios.post(func); // 等待线程退出 for(int i = 0; i < thread_num; ++i) { t[i]->join(); }
很容易看出來,這種執行緒池的瓶頸在於一個任務佇列,多個執行緒競爭取任務,在大並發的程式裡面容易導致效能下降。
另一種是每個執行緒各自維護一個任務佇列,使用者可以選擇隨機或輪訓地投遞任務到其中一個任務佇列裡面,該任務佇列中的任務只由其所在的執行緒才能消費。這種執行緒池在boost的example裡面也有對應的實作(io_service_pool),基本方法是建立多個io_service對象,每個對應一個thread,程式碼如下:
using namespace boost; using namespace boost::asio; int thread_num = 10; io_service ios[thread_num]; thread *t[thread_num] = {0}; // 创建线程池 for(int i = 0; i < thread_num; ++i) { t[i] = new thread(bind(&io_service::run, &ios[i])); } // 轮训投递任务 for(int i = 0; i < thread_num; ++i) { ios[i].post(func); } // 等待线程退出 for(int i = 0; i < thread_num; ++i) { t[i]->join(); }
以下是基於linux環境作的類別圖,因為在windows上,有些類別有不同的定義。
io_service定義了主要的接口,在linux下的實作是task_io_service。
task_io_service主要定義了三個東西:
一個reactor,reactor就是完成連接埠、select、poll、epoll之類的事件磁碟機;
一個公共的任務佇列op_queue,用來存放使用者post的任務,和reactor傳回的任務;
執行緒相關變數。 io_service本身不會建立任何線程,但它會保存一些線程呼叫訊息,例如線程私有隊列等。
此外,task_io_service也維護了一個空閒執行緒列表,在有多餘任務到來時,喚醒其中一個空閒執行緒。在常見的linux單任務佇列的線程池裡面,用一個condition變數來喚醒線程,在多核心系統裡面,一次pthread_cond_signal調用,會喚起處於wait狀態的一個或多個線程(參考https://linux.die. net/man/3/pthread_cond_signal),儘管只有一個任務,如果採用空閒線程的方法,有任務時只喚醒一個空閒線程,可以減少很多不必要喚醒。
thread_info_base類別維護了一個簡單的記憶體池,只有一塊內存,僅在連續的申請釋放記憶體情況下,可以減少記憶體開啟的開銷。
io_service::work的作用:io_service::run在任務執行完畢時會立刻返回,這並不是寫常駐服務的程式所想要的,boost給的解決方案是定義一個work變量,乍看很神奇,這個跟io_server似乎沒有任何關係的變數竟然能控制run的行為,打開源碼一看,work的實作簡單的出奇,它只是在建構函式裡呼叫io_service的worked_started()方法,使其待處理任務數( outstanding_work_)大於0,如此,io_service::run就認為一直有任務待處理而不回傳了。
相關建議:
Angular 根據 service 的狀態更新 directive_AngularJS
簡介AngularJS中使用factory和service的方法_AngularJS
#
#以上是boost::io_service解讀的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

Java 8引入了Stream API,提供了一種強大且表達力豐富的處理數據集合的方式。然而,使用Stream時,一個常見問題是:如何從forEach操作中中斷或返回? 傳統循環允許提前中斷或返回,但Stream的forEach方法並不直接支持這種方式。本文將解釋原因,並探討在Stream處理系統中實現提前終止的替代方法。 延伸閱讀: Java Stream API改進 理解Stream forEach forEach方法是一個終端操作,它對Stream中的每個元素執行一個操作。它的設計意圖是處

PHP是一種廣泛應用於服務器端的腳本語言,特別適合web開發。 1.PHP可以嵌入HTML,處理HTTP請求和響應,支持多種數據庫。 2.PHP用於生成動態網頁內容,處理表單數據,訪問數據庫等,具有強大的社區支持和開源資源。 3.PHP是解釋型語言,執行過程包括詞法分析、語法分析、編譯和執行。 4.PHP可以與MySQL結合用於用戶註冊系統等高級應用。 5.調試PHP時,可使用error_reporting()和var_dump()等函數。 6.優化PHP代碼可通過緩存機制、優化數據庫查詢和使用內置函數。 7

PHP和Python各有優勢,選擇應基於項目需求。 1.PHP適合web開發,語法簡單,執行效率高。 2.Python適用於數據科學和機器學習,語法簡潔,庫豐富。

PHP適合web開發,特別是在快速開發和處理動態內容方面表現出色,但不擅長數據科學和企業級應用。與Python相比,PHP在web開發中更具優勢,但在數據科學領域不如Python;與Java相比,PHP在企業級應用中表現較差,但在web開發中更靈活;與JavaScript相比,PHP在後端開發中更簡潔,但在前端開發中不如JavaScript。

PHP和Python各有優勢,適合不同場景。 1.PHP適用於web開發,提供內置web服務器和豐富函數庫。 2.Python適合數據科學和機器學習,語法簡潔且有強大標準庫。選擇時應根據項目需求決定。

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

PHP成為許多網站首選技術棧的原因包括其易用性、強大社區支持和廣泛應用。 1)易於學習和使用,適合初學者。 2)擁有龐大的開發者社區,資源豐富。 3)廣泛應用於WordPress、Drupal等平台。 4)與Web服務器緊密集成,簡化開發部署。

PHP適用於Web開發和內容管理系統,Python適合數據科學、機器學習和自動化腳本。 1.PHP在構建快速、可擴展的網站和應用程序方面表現出色,常用於WordPress等CMS。 2.Python在數據科學和機器學習領域表現卓越,擁有豐富的庫如NumPy和TensorFlow。
