多線程編程中 開優(yōu)化選項時要謹慎否則容易掉坑里
先看下面的代碼,開起兩個線程,第二個線程把第一個線程的循環(huán)條件置成false 按邏輯來說這個應該能順利結(jié)束的不過如果用
g++ -O3 -o multiThread multiThread.cpp -lpthread
編譯的話TestThread1是退不出來的,只有 g_brun 加上 volatile關(guān)鍵字才能正常退出
因為在-O3優(yōu)化選項下 執(zhí)行TestThread1時g_brun會先讀到寄存器中,編譯器發(fā)現(xiàn)這個函數(shù)中g(shù)_brun沒有任何改變所以不會再去內(nèi)存中取值直接用寄存器中的備份,在TestThread2中改變了g_brun在內(nèi)存中的值,對TestThread1中g(shù)_brun的寄存器備份沒有任何影響。
加上volatile表示對該變量不優(yōu)化每次都去內(nèi)存中取值。
創(chuàng)新互聯(lián)公司于2013年成立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務公司,擁有項目網(wǎng)站制作、成都網(wǎng)站制作網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元玉龍做網(wǎng)站,已為上家服務,為玉龍各地企業(yè)和個人服務,聯(lián)系電話:13518219792
#include <pthread.h>
#include <iostream>
#include <unistd.h>
using namespace std;
//volatile bool g_brun = true;
bool g_brun = true;
void* TestThread1(void* arg)
{
cout << "TestThread1 進入" << endl;
long long ll = 0;
while(g_brun)
ll ++;
cout << "TestThread1 退出 ll:" << ll << endl;
}
void* TestThread2(void* arg)
{
cout << "TestThread2 進入" << endl;
g_brun = false;
cout << "TestThread2 退出 設置 g_brun = false" << endl;
}
int main()
{
pthread_t threadId1;
pthread_create(&threadId1, NULL, TestThread1, NULL);
usleep(1000000); // 保證TestThread1先執(zhí)行
pthread_t threadId2;
pthread_create(&threadId2, NULL, TestThread2, NULL);
pthread_join(threadId1,NULL);
pthread_join(threadId2,NULL);
return 0;
}
網(wǎng)站標題:多線程的坑--volatile
當前地址:http://muchs.cn/article32/gddcpc.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供動態(tài)網(wǎng)站、虛擬主機、用戶體驗、靜態(tài)網(wǎng)站、微信公眾號、電子商務
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)