我对线程是个新手。在这里,如果我注释pthread_join( thread1,NULL),那么在输出中有时我会得到
Thread2
Thread1
Thread1我不能理解为什么Thread1跟踪会出现两次,以及pthread_join的确切功能是什么。
另外,请参考一些针对初学者的线程概念教程。
void *print_message_function( void *ptr );
main()
{
pthread_t thread1, thread2;
char *message1 = "Thread 1";
char *message2 = "Thread 2";
int iret1, iret2;
iret1 = pthread_create( &thread1, NULL, print_message_function, (void*) message1);
iret2 = pthread_create( &thread2, NULL, print_message_function, (void*) message2);
pthread_join( thread1, NULL);
pthread_join( thread2, NULL);
printf("Thread 1 returns: %d\n",iret1);
printf("Thread 2 returns: %d\n",iret2);
exit(0);
}
void *print_message_function( void *ptr )
{
char *message;
message = (char *) ptr;
printf("%s \n", message);
}发布于 2012-04-26 10:31:14
如果我得到这些结果,首先我将执行以下操作:
1)而不是下面的行,
iret1 = pthread_create( &thread1, NULL, print_message_function, (void*) message1);
iret2 = pthread_create( &thread2, NULL, print_message_function, (void*) message2);
pthread_join( thread1, NULL);
pthread_join( thread2, NULL); 将其替换为,
iret1 = pthread_create( &thread1, NULL, print_message_function, (void*) message1);
pthread_join( thread1, NULL);
iret2 = pthread_create( &thread2, NULL, print_message_function, (void*) message2);
pthread_join( thread2, NULL); 看看结果是什么。
2)在线程函数中,需要调用pthread_exit(" exit ");这是退出线程函数的正确方法。在函数结束时执行此操作。
void *print_message_function( void *ptr )
{
char *message;
message = (char *) ptr;
printf("%s \n", message);
pthread_exit("Exit");
}如果你是这样做的,理想情况下你不会遇到任何问题。在任何情况下,我都假定您是使用gcc -D_REENTRANT -o threadex threadex.c -lpthread编译程序的
这不是最终的解决方案。如果运行正常,那么我们可以继续下一步,同时启动两个线程。
请在合并这些更改后分享反馈。
发布于 2012-04-26 10:05:05
可能输出缓冲区未正确刷新。在执行多线程并将输出通过管道传输到文件时,我遇到过一个非常类似的问题--有时输出会出现两次。尝试将这一行添加到main函数中:
setvbuf(stdout, NULL, _IONBF, 0);这将强制在每次写入时刷新输出缓冲区。
https://stackoverflow.com/questions/10322175
复制相似问题