C++11/14 線程的創(chuàng)建與分離的實(shí)現(xiàn)
線程的創(chuàng)建
讓我們看看示例代碼(t1.cpp).
#include <iostream> #include <thread> void thread_function() { std::cout << "thread function\n"; } int main() { std::thread t(&thread_function); // 線程 t 開始運(yùn)行 std::cout << "main thread\n"; t.join(); // 主線程等待子線程結(jié)束 return 0; }
代碼在linux系統(tǒng)下將輸出:
$ g++ t1.cpp -o t1 -std=c++11 -pthread $ ./t2 thread function main thread
我們要做的第一件事是創(chuàng)建一個(gè)線程對(duì)象(工作線程),并給它一個(gè)函數(shù)形式的任務(wù)進(jìn)行工作。
主線程希望等待線程成功完成。
所以,我們使用join(). 如果最初的主線程不等待新線程執(zhí)行完成,那么它會(huì)繼續(xù)執(zhí)行main()函數(shù)之后的代碼,可能在新線程執(zhí)行完畢前結(jié)束程序。
當(dāng)主線程在等待時(shí),主線程處于空閑狀態(tài)。
實(shí)際上,操作系統(tǒng)可能會(huì)把CPU資源從主線程上移走。
請(qǐng)注意,我們?cè)诰€程的函數(shù)和類的聲明中有一個(gè)新的標(biāo)準(zhǔn)C++庫(kù)頭文件#include <thread>
。
下圖是流程的流程圖
然而,在實(shí)際執(zhí)行中,事情并不是那么理想,更可能是不對(duì)稱的。也許,它看起來(lái)更像下面這張圖片。
當(dāng)工作線程開始構(gòu)造std::thread t的時(shí)候,可能會(huì)有創(chuàng)建時(shí)的開銷(通過(guò)使用線程池可以減少此開銷),圖中虛線表示可能的阻塞狀態(tài)。
線程的分離
我們可以創(chuàng)建一個(gè)新線程使其運(yùn)行為自由的守護(hù)進(jìn)程。
// t2.cpp int main() { std::thread t(&thread;_function); std::cout << "main thread\n"; // t.join(); t.detach(); return 0; }
分離的子線程現(xiàn)在是自由的,并自行運(yùn)行。它變成了一個(gè)守護(hù)進(jìn)程。
$ g++ t2.cpp -o t2 -std=c++11 -pthread $ ./t2 main thread
注意,分離線程沒有改變打印輸出到標(biāo)準(zhǔn)輸出stdout,因?yàn)橹骶€程已經(jīng)結(jié)束并退出。
這是多線程編程的特點(diǎn)之一:我們不能確定哪個(gè)線程首先運(yùn)行 (不確定性,除非我們使用同步機(jī)制。). 在我們的例子中,由于創(chuàng)建一個(gè)新線程需要一定的時(shí)間,主線程最有可能比子線程率先執(zhí)行完畢。
還有一點(diǎn)我們需要注意的是,即使在這個(gè)簡(jiǎn)單的代碼中,我們也在共享一個(gè)公共資源:std::cout。
因此,為了使代碼正常工作,主線程應(yīng)該允許我們的子線程訪問資源。
一旦一個(gè)線程分離,我們不能強(qiáng)迫它與主線程重新連接。因此,下面的代碼行是錯(cuò)誤的,程序會(huì)崩潰。
int main() { std::thread t(&thread;_function); std::cout << "main thread\n"; // t.join(); t.detach(); t.join(); // Error return 0; }
一旦脫離,線程就應(yīng)該永遠(yuǎn)是脫離狀態(tài).
我們可以使用joinable()把代碼做崩潰前的檢查。
因?yàn)樗黬oinable()返回為false,join()函數(shù)不會(huì)被調(diào)用,程序運(yùn)行不會(huì)崩潰。
int main() { std::thread t(&thread;_function); std::cout << "main thread\n"; // t.join(); if(t.joinable()) t.join(); return 0; }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
上一篇:C語(yǔ)言實(shí)現(xiàn)餐飲點(diǎn)餐管理系統(tǒng)
欄 目:C語(yǔ)言
下一篇:C++小知識(shí):復(fù)制粘貼代碼千萬(wàn)要小心
本文標(biāo)題:C++11/14 線程的創(chuàng)建與分離的實(shí)現(xiàn)
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/486.html
您可能感興趣的文章
- 04-02c語(yǔ)言的正則匹配函數(shù) c語(yǔ)言正則表達(dá)式函數(shù)庫(kù)
- 04-02c語(yǔ)言中對(duì)數(shù)函數(shù)的表達(dá)式 c語(yǔ)言中對(duì)數(shù)怎么表達(dá)
- 04-02C語(yǔ)言中怎么打出三角函數(shù) c語(yǔ)言中怎么打出三角函數(shù)的值
- 01-10c語(yǔ)言求1+2+...+n的解決方法
- 01-10求子數(shù)組最大和的解決方法詳解
- 01-10深入理解約瑟夫環(huán)的數(shù)學(xué)優(yōu)化方法
- 01-10深入二叉樹兩個(gè)結(jié)點(diǎn)的最低共同父結(jié)點(diǎn)的詳解
- 01-10數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)- 解析最少換車次數(shù)的問題詳解
- 01-10c語(yǔ)言 跳臺(tái)階問題的解決方法
- 01-10如何判斷一個(gè)數(shù)是否為2的冪次方?若是,并判斷出來(lái)是多少次方


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02c語(yǔ)言函數(shù)調(diào)用后清空內(nèi)存 c語(yǔ)言調(diào)用
- 04-02func函數(shù)+在C語(yǔ)言 func函數(shù)在c語(yǔ)言中
- 04-02c語(yǔ)言的正則匹配函數(shù) c語(yǔ)言正則表達(dá)
- 04-02c語(yǔ)言用函數(shù)寫分段 用c語(yǔ)言表示分段
- 04-02c語(yǔ)言中對(duì)數(shù)函數(shù)的表達(dá)式 c語(yǔ)言中對(duì)
- 04-02c語(yǔ)言編寫函數(shù)冒泡排序 c語(yǔ)言冒泡排
- 04-02c語(yǔ)言沒有round函數(shù) round c語(yǔ)言
- 04-02c語(yǔ)言分段函數(shù)怎么求 用c語(yǔ)言求分段
- 04-02C語(yǔ)言中怎么打出三角函數(shù) c語(yǔ)言中怎
- 04-02c語(yǔ)言調(diào)用函數(shù)求fibo C語(yǔ)言調(diào)用函數(shù)求
隨機(jī)閱讀
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 04-02jquery與jsp,用jquery
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10delphi制作wav文件的方法
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文