99热这里只有精品2-99热这里只有精品6免费-99热这里只有精品国产99-99热这里只有精品国产99热门精品-99热这里只有精品国产动漫

編程代碼
新聞詳情

C++ 線程間同步

發布時間:2021-03-29 09:36:33 最后更新:2021-03-30 09:02:29 瀏覽次數:4287

0 前言

  • 多線程在運行過程中,各個線程都是隨著 OS 的調度算法,占用 CPU 時間片來執行指令做事情,每個線程的運行完全沒有順序可言。
  • 在某些應用場景下,一個線程需要等待另外一個線程的運行結果,才能繼續往下執行,這就涉及到線程之間的同步通信機制。
  • 線程間同步通信最典型的例子就是生產者-消費者模型,生產者線程生產出產品以后,會通知消費者線程去消費產品;當消費者線程去消費產品時,發現還沒有產品生產出來,它需要通知生產者線程趕快生產產品,等生產者線程生產出產品以后,消費者線程才能繼續往下執行。

1 消費者“被動等待”

#include 
#include 
#include 

static std::mutex mtx;
static std::deque<int> dq;
static int productNum = 5;

void Producer()
{
    using namespace std::literals::chrono_literals;
    for (int i = 1; i <= productNum; ++i) {
        mtx.lock();
        dq.push_front(i);
        std::cout << "Producer 生產產品為: " << i << std::endl;
        mtx.unlock();
        // std::this_thread::sleep_for(1s);
    }
}

void Consumer()
{
    while (true) {
        if (dq.empty()) {
            continue;
        }
        mtx.lock();
        int data = dq.back();
        dq.pop_back();
        std::cout << "Consumer 消費產品為: " << data << std::endl;
        mtx.unlock();
    }
}

int main()
{
    std::thread t1(Producer);
    std::thread t2(Consumer);
    t2.join();
    t1.join();
    std::cin.get();
}

程序運行結果如下:

C++ 線程間同步

如果讓生產者線程每生產一個產品后休息(sleep) 1s,結果如下:

C++ 線程間同步

解釋:該例子中,生產者和消費者分別對應兩個線程。隊列中存在物品時,消費者去消費,否則空循環,一直等待。

缺點:當雙端隊列中沒有物品時,消費者只會原地死等,不會去催。

2 消費者“主動出擊”

#include 
#include 
#include 
#include 
#include 
  
std::mutex mtx;
std::condition_variable cv;
std::vector<int> vec;
int productNum = 5;

void Producer()
{
    for (int i = 1; i <= productNum; ++i) {
        std::unique_lock<std::mutex> lock(mtx);
        while (!vec.empty()) {
            cv.wait(lock); // vec 不為空時阻塞當前線程
        }
        vec.push_back(i);
        std::cout << "Producer生產產品: " << i << std::endl;
        cv.notify_all(); // 釋放線程鎖
    }
}

void Consumer()
{
    while (true) {
        std::unique_lock<std::mutex> lock(mtx);
        while (vec.empty()) {
            cv.wait(lock); // vec 為空時等待線程鎖。其他線程鎖釋放時,當前線程繼續執行
        }
        int data = vec.back();
        vec.pop_back();
        std::cout << "Consumer消費產品: " << data << std::endl;
        cv.notify_all();
    }
}

int main()
{
    std::thread t1(Producer);
    std::thread t2(Consumer);
    t2.join();
    t1.join();
    std::cin.get();
}

程序運行結果如下:

C++ 線程間同步

解釋:該例子中,生產者和消費者分別對應兩個線程。只要 vector 中存在物品時,生產者線程就阻塞,通知消費者線程去消費;vector 中不存在物品時,消費者線程阻塞,通知生產者去生產。

3 線程加入方式 join 和 detach

join:采用 join 方式,t1、t2 亂序執行,且外層主線程會等到 t1、t2 都結束了再繼續執行后面的代碼。

detach:如果采用 detach 方式,t1、t2 亂序執行,且脫離了外層主線程。外層主線程執行結束時,t1、t2 可能還沒結束,但此時程序就退出了。


如涉及侵權,請相關權利人與我司聯系刪除

在線客服 雙翌客服
客服電話
  • 0755-23712116
  • 13310869691
主站蜘蛛池模板: 国产91精品在线播放| 国内精品91| 老人与老人一级毛片| 91免费公开视频| 久久国产精品岛国搬运工| 国产成人一区二区三区| 精品毛片| 97在线国产视频| 色拍拍在线精品视频| 国产视频亚洲| 高清性色生活片免费观看 | 毛片 ftp| 国产一级精品高清一级毛片| yiren22开心综合成人网| 麻豆精品国产剧情在线观看| 九九精品在线视频| 极品一区| 欧美亚洲一区| 爱福利一区二区| asian极品呦女爱爱| 国产又黄又潮娇喘视频免费| 欧美日韩国产成人高清视频| 一级做a爰片久久毛片人呢| 成年黄网站免费大全毛片| 视频一区二区不卡| 精品三级在线| 看大片免费一| 青青青国产依人在线视频97| 一级午夜a毛片免费视频| 日本无卡无吗中文免费| 男人你懂的网站| 欧美日韩一区二区视频图片| 国产日韩精品在线| 黄色a级网站| 最新大黄网站免费| 精品国产欧美另类一区| 免费变态视频网站| 欧美一区二区三区不卡免费观看| chinese麻豆自制国产| 三级黄色免费网站| 中国女人a毛片免费全部播放|