为什么 cout 不适用于 pthreads?

Why cout doesn't work with pthreads?

本文关键字:pthreads 适用于 不适用 cout 为什么      更新时间:2023-10-16

我正在尝试一个简单的程序来测试多线程。我只是在交替的线程中打印一系列"x"answers"O"。现在,如果我使用cout,屏幕上看不到任何输出。如果我使用fputc和output来执行错误操作,它可以正常工作。为什么cout(输出到标准输出)在这里不起作用?

代码如下:

#include <iostream>
#include <pthread.h>
#include <unistd.h>
#include <stdio.h>
using namespace std;
static int count;
void* print_xs(void *unused)
{
    while(1)
    {
        if (count >=100) break;
        if (count%2==0)
        {
            count++;
            cout<<"X=";  // no output here
            fputc('X',stderr); // works !
        }
        else
        {
            sleep(1);
        }
    }
    return NULL;
}

int main()
{
    pthread_t tid;
    pthread_create(&tid,NULL,&print_xs, NULL);
    while(1)
    {
        if (count >=100) break;
        if (count%2!=0)
        {
            count++;
            cout<<"O="; // no output here 
            fputc('O',stderr); // works !
        }
        else
        {
            sleep(1);
        }
    }
    pthread_join(tid,NULL);
    return (0);
}

由于std::cout缓冲流,您需要刷新它以便将缓冲区发送到标准输出。

试试这样写:

cout<< "O=";
cout.flush();

应该可以。

<标题>附加指出h1> li>正如一些评论已经建议您的,std::cout在c++ 03和之前不是线程安全的。用互斥锁来保护这个对象可能会很有用。这可能不是问题,因为 c++ 11标准。

FDIS在§27.4.1 [iostream.objects.overview]中说:

通过多个线程并发访问synchronized(§27.5.3.4)标准iostream对象的格式化和未格式化的输入(§27.7.2.1)和输出(§27.7.3.1)函数或标准C流不会导致数据竞争(§1.10)。[注:如果用户希望避免交叉字符,他们仍然必须同步多线程对这些对象和流的并发使用。]

这意味着如果没有互斥锁,可以保证对象在数据竞争上下文中不会损坏。但重叠产出的问题依然存在。因此,如果您确保每一行都被另一个线程打印而没有重叠,您仍然需要一个互斥锁。
  • c++ 11引入了一个多线程库(通常是pthread的包装器)。这里有一些参考资料。看一看,你会发现它很有用。