12

以下打印

In Main()
Hello World
Hello World

为什么这会打印两次 Hello World?如果我使用 pthread_join() 会出现所需的输出(只有一个 Hello World 前面是 In Main()。

#include <pthread.h>

void *thread_func(void *arg);

int main(int argc, char **argv)
{
    int s;
    void *res;
    pthread_t t1;

    s = pthread_create(&t1, NULL, thread_func, "Hello World\n");

    if (s != 0)
        printf("Err\n");

    printf("In Main()\n");

    s = pthread_detach(t1);

    if (s != 0)
        printf("Err\n");

    return 0;
}

void *thread_func(void *arg)
{
    char *s = (char *)arg;
    printf("%s", s);
    pthread_exit(0);
}

我了解 pthread_detach 告诉库在线程终止后释放 pthread 使用的所有资源......并且由于我在 thread_func 结束时终止它,所以一切都应该没问题吧?

我在这里想念什么?

4

1 回答 1

3

在我看来,您使用的是标准库的非线程安全版本(prints、fflush ...)。我已经在旧的类 unix 实时系统上看到了这种(显然)非逻辑行为。有两种不同版本的 std 库,一种用于单线程模式,一种用于多线程模式。当然,默认是单线程的……一般来说,对文件指针和类似东西的访问应该用互斥锁序列化。在您的程序中,有两个线程终止,每个可能都想隐式调用 fflush,但由于底层缓冲区不打算同时访问,因此可能会发生两个刷新都将相同的数据写入输出文件描述符的情况。

于 2012-11-10T08:34:53.370 回答