这是我的主要功能,NO_RECIEVERS = 3
。我试图使用我发送的i
的值来区分编写器和读取器线程。
int main() {
int status, i;
pthread_t tr[NO_RECIEVERS], tw[NO_SENDERS], bd;
i=1;
for(i=1; i<=NO_SENDERS; i++) {
pthread_create(&tw[i-1], NULL, writer, &i);
}
for(i=1; i<=NO_RECIEVERS; i++) {
printf("%d\n", i);
pthread_create(&tr[i-1], NULL, reader, &i);
}
pthread_create(&bd, NULL ,daemon_thread, NULL);
for(i=1; i<=NO_SENDERS; i++) {
pthread_join(tw[i-1], NULL);
}
for(i=1; i<=NO_RECIEVERS; i++) {
pthread_join(tr[i-1], NULL);
}
pthread_join(bd, NULL);
return 0;
}
我的读者功能如下
void* reader(void *val) {
int ret, fd, id;
struct mssg data;
id = *(int*)val;
printf("id: %d %d\n", id, *(int*)val);
while(1) {
但是这个函数似乎是在创建一些带有id的随机值的线程..我得到一个像这样的日志
...
id: 1 1
...
id: 2 2
...
id: 1 1
下次我得到......它的随机
...
id: 1 1
...
2
id: 2 2
...
id: 4 4
但我指定的值仅限于1,2,3
答案 0 :(得分:3)
您已将&i
传递给您创建的所有主题...因此每个主题都有一个指向i
的指针,当它们取消引用它以读取i
的值时,以及他们读到的是当时恰好有的i
。
如果您想在i
时传递pthread_create
的值,我建议malloc()
一小块内存,将i
复制到其中并通过malloced事物到线程(可以读取它和free()
内存。或者为每个创建的线程在不同位置提供i
副本的任何其他方法。