为什么我的程序会打印垃圾?

时间:2016-01-10 19:47:15

标签: c++ multithreading synchronization

我的代码:

#include <iostream>
#include <thread>

void function_1()
{
    std::cout << "Thread t1 started!\n";
    for (int j=0; j>-100; j--) {
        std::cout << "t1 says: " << j << "\n";
    }
}

int main()
{
    std::thread t1(function_1); // t1 starts running

    for (int i=0; i<100; i++) {
        std::cout << "from main: " << i << "\n";
    }

    t1.join(); // main thread waits for t1 to finish
    return 0;
}

我创建一个thread按递减顺序打印数字,而main按递增顺序打印。

示例输出here。为什么我的代码会打印垃圾?

2 个答案:

答案 0 :(得分:11)

两个线程同时输出,从而扰乱输出。 您需要在打印部件上使用某种线程同步机制。

请参阅this answer,了解使用std::mutexcout <table th:attr="data-availible-dates=${defoultSetting.avalibleDates}"> 相结合的示例。

答案 1 :(得分:9)

不是&#34;垃圾&#34; - 它是你要求的输出!它只是乱七八糟,因为你已经使用了大量的同步机制来防止单个std::cout << ... << std::endl行(非原子)被类似的行中断(在另一个主题中仍然不是原子的。

传统上,我们会在每条线路周围锁定互斥锁