为什么我的程序打印垃圾

Why is my program printing garbage?

本文关键字:打印 程序 我的 为什么      更新时间:2023-10-16

我的代码:

#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按递增顺序打印。

此处为输出示例。为什么我的代码打印是垃圾?

两个线程同时输出,从而扰乱您的输出。打印部分需要某种线程同步机制。

有关使用std::mutexstd::lock_guard组合作为cout的示例,请参见此答案。

这不是"垃圾"—这是你要求的输出!它只是一团糟,因为您总共使用了同步机制来防止单个std::cout << ... << std::endl行(非原子)被其他线程中的类似行(仍然不是原子)中断。

传统上,我们会在每一行周围锁定一个互斥锁