欧美日韩在线第一页-欧美日韩在线观看精品-欧美日韩在线观看一区二区-欧美日韩在线免费看-欧美日韩在线视频不卡一区二区三区

編程代碼
新聞詳情

C++11多線程編程(八)——死鎖問題

發(fā)布時(shí)間:2021-01-07 14:00:41 瀏覽次數(shù):2864

一、死鎖現(xiàn)象

看到“死鎖”二字,你是不是慌得不知所措。死鎖,顧名思義就是這個(gè)鎖死掉了,再也動(dòng)不了了。那死鎖是怎么產(chǎn)生的呢?當(dāng)你對某個(gè)資源上鎖后,卻遲遲沒有釋放或者根本就無法釋放,導(dǎo)致別的線程無法獲得該資源的訪問權(quán)限,進(jìn)而程序無法運(yùn)行下去,有點(diǎn)像是阻塞的現(xiàn)象。但是阻塞是一種正常現(xiàn)象,而死鎖可以說是一種bug,必須要處理。

C++11多線程編程(八)——死鎖問題

那么我現(xiàn)在就舉個(gè)死鎖的例子,來分析分析。

#include <iostream>
#include <thread>
#include <mutex>
using namespace std;
 
mutex mt1;
mutex mt2;
void thread1()
{
    cout << "thread1 begin" << endl;
    lock_guard<mutex> guard1(mt1);
    this_thread::sleep_for(chrono::seconds(1));
    lock_guard<mutex> guard2(mt2);
    cout << "hello thread1" << endl;
}
void thread2()
{
    cout << "thread2 begin" << endl;
    lock_guard<mutex> guard1(mt2);
    this_thread::sleep_for(chrono::seconds(1));
    lock_guard<mutex> guard2(mt1);
    cout << "hello thread2" << endl;
}
 
int main()
{
    thread t1(thread1);
    thread t2(thread2);
    t1.join();
    t2.join();
    cout << "thread end" << endl;
    return 0;
}

二、死鎖分析

因?yàn)槌绦蜻\(yùn)行的是非常快的,所以為了產(chǎn)生死鎖現(xiàn)象,我們各自休眠了1秒。

運(yùn)行以上程序可以發(fā)現(xiàn),程序在輸出完“thread1 beginthread2 begin”后,就卡在那里,程序運(yùn)行可能發(fā)生了以下這種情況:

thread1              thread2
mt1.lock()           mt2.lock()
//死鎖               //死鎖
mt2.lock()           mt1.lock()

thread1中的mt2在等待著thread2的mt2釋放鎖,而thead2中mt1卻也在等待著thread1的mt1釋放鎖,互相都在等待著對方釋放鎖,進(jìn)而產(chǎn)生了死鎖。必須強(qiáng)調(diào)的是,這是一種bug,必須避免。那么如何避免這種情況呢?

三、死鎖解決

1、每次都先鎖同一個(gè)鎖

比如像上面thread1和thread2線程,我們每次都先鎖mt1,再鎖mt2,就不會(huì)發(fā)生死鎖現(xiàn)象。

2、給鎖定義一個(gè)層次的屬性,每次按層次由高到低的順序上鎖,這個(gè)原理也是每次都先鎖同一個(gè)鎖。

C++標(biāo)準(zhǔn)庫中提供了std::lock()函數(shù),能夠保證將多個(gè)互斥鎖同時(shí)上鎖。

std::lock(mt1, mt2);

那么既然在最前面就已經(jīng)上鎖了,后面就不需要上鎖了,而C++標(biāo)準(zhǔn)庫并沒有提供std::unlock()的用法,所以還是需要用到lock_guard,但是需要修改一點(diǎn)。加個(gè)std::adopt_lock就可以了。

lock_guard<mutex> guard1(mt1, adopt_lock);
lock_guard<mutex> guard2(mt2, adopt_lock);

這個(gè)表示構(gòu)造函數(shù)的時(shí)候不要給我上鎖,到析構(gòu)的時(shí)候你要記得給我解鎖。

這個(gè)就是死鎖的一些解決方法,同時(shí)大家一定要記得盡量不要一段定義域內(nèi)多次使用互斥鎖,如果不可避免的要使用,一定要記得給鎖定義順序,或者使用要使用std::lock()上鎖。

相關(guān)閱讀:

在線客服 雙翌客服
客服電話
  • 0755-23712116
  • 13310869691
主站蜘蛛池模板: 国产高清美女一级a毛片久久w| 一级福利片| 污污的免费网站| 婷婷色站| 在线看污片| 亚洲欧美精品一区二区| 91久久青草精品38国产| 青青黄色| 中日欧洲精品视频在线| 国产αv| 免费一区在线| 亚洲色图综合网| 国内色视频| 国产精品乱码免费一区二区 | 国产牛仔裤系列在线观看| 色黄网站在线观看| 综合国产在线| 婷婷色青基地| 亚洲欧美日本人成在线观看 | 国产v综合v亚洲欧美大另类 | 美女高清视频喷水| 中文字幕永久在线视频| 美女久久久久| 欧美日韩顶级毛片www免费看| 97视频免费在线| 酒色成人网| 日本国产最新一区二区三区| 国内色视频| 成人免费福利视频| 青娱乐黄色| 国内永久第一免费福利视频| 91免费网站| 特级aa毛片在线播放| 日本黄色片www| 国产福利小视频| 亚洲高清在线观看视频| 欧美成人香蕉网在线观看| 欧美成a人片免费看久久| 亚洲欧美日韩成人一区在线| 国产精品一区二区三区免费视频| 三级毛片在线免费观看|