熱線電話:0755-23712116
郵箱:contact@shuangyi-tech.com
地址:深圳市寶安區(qū)沙井街道后亭茅洲山工業(yè)園工業(yè)大廈全至科技創(chuàng)新園科創(chuàng)大廈2層2A
首先還是那個(gè)問題,我們?yōu)槭裁葱枰嗑€程?單線程編程做的好好的,又簡單又好用,為什么要弄出一個(gè)多線程編程呢?難道前人是為了設(shè)計(jì)而設(shè)計(jì)了個(gè)多線程的?顯然這是不可能,那么是什么原因呢?用最精煉的語言概括無非就是以下兩個(gè)原因。
效率和用戶體驗(yàn)
效率主要體現(xiàn)在服務(wù)端,用戶體驗(yàn)更多是體現(xiàn)在客戶端,當(dāng)然肯定不是說效率只體現(xiàn)在服務(wù)端,用戶體驗(yàn)只體現(xiàn)在客戶端,無論是效率還是用戶體驗(yàn)在服務(wù)端和客戶端上都會(huì)體現(xiàn),只是說側(cè)重點(diǎn)不一樣,這一點(diǎn)大家要注意下。
那么多線程到底是什么呢?在計(jì)算機(jī)術(shù)語中也可以叫并發(fā),指的是在單個(gè)系統(tǒng)里同時(shí)執(zhí)行多個(gè)獨(dú)立的活動(dòng),而不是順序的一個(gè)接一個(gè)的執(zhí)行。假設(shè)這樣的一個(gè)場(chǎng)景,你在一個(gè)軟件中要導(dǎo)入100萬條的數(shù)據(jù),如果你用單線程,那么你在導(dǎo)入的過程中,你只能等待它導(dǎo)完,其他什么事你都做不了,因?yàn)檐浖?huì)卡在那里,之所以卡在那里,是因?yàn)檐浖锩嬖趥鬏敂?shù)據(jù),而你是用單線程,數(shù)據(jù)還沒傳輸完,下面的代碼無法執(zhí)行。所以這個(gè)時(shí)候你必須用多線程,開啟一個(gè)線程來導(dǎo)入這100萬條數(shù)據(jù),這樣才能保證在導(dǎo)入數(shù)據(jù)的同時(shí),你還可以在軟件上做其他操作。
大家要注意一點(diǎn),在單核CPU上面,并發(fā)并不是真正的并發(fā),而是通過時(shí)間片輪詢的方式來看起來像是并發(fā),真正的并發(fā)應(yīng)該是在多核CPU上面。
說完了多線程的相關(guān)概念,我們來說一說多線程編程。在早期C++11之前,C++在語言級(jí)別上并不支持多線程,要想實(shí)現(xiàn)多線程,必須通過第三方庫或者調(diào)用平臺(tái)系統(tǒng)函數(shù)來實(shí)現(xiàn)的,而不同平臺(tái)的多線程的系統(tǒng)函數(shù)又都不一樣,所以給多線程編程帶來了很多麻煩。但是從C++11開始,C++終于開始在語言級(jí)別上支持多線程,我們也終于可以用一份代碼在多個(gè)平臺(tái)上跑了。
那么C++如何實(shí)現(xiàn)線程呢?以下是一個(gè)實(shí)現(xiàn)線程的簡單的例子
#include <iostream>
#include <thread>
using namespace std;
void thread_task()
{
cout << "hello thread" << endl;
}
int main()
{
thread t(thread_task);
t.join();
cout << "thread end" << endl;
return 0;
}
thread t(thread_task)這個(gè)是打開C++多線程世界的一個(gè)最簡單也是最基礎(chǔ)的一行代碼,從此C++開始從語言級(jí)別上支持了多線程。
以上是一個(gè)非常簡單的C++多線程的例子,main函數(shù)是主線程,thread_task是子線程,thread t(thread_task)意思是啟動(dòng)這個(gè)子線程,join()會(huì)使主線程會(huì)被阻塞,直到子線程執(zhí)行完畢,然后才退程序。
所以從這個(gè)例子大家可以看出C++多線程寫法是多么的簡潔,讓人充滿的學(xué)習(xí)的欲望。