C pthread参数';s值已更改
这是我的主要功能,其中C pthread参数';s值已更改,c,linux,multithreading,pthreads,C,Linux,Multithreading,Pthreads,这是我的主要功能,其中无接收器=3。我试图使用我发送的I的值来区分writer线程和reader线程 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); }
无接收器=3
。我试图使用我发送的I
的值来区分writer线程和reader线程
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;
}
但是这个函数似乎正在创建id为一些随机值的线程。。我有这样的日志
...
id: 1 1
...
id: 2 2
...
id: 1 1
下次我得到。。它是随机的
...
id: 1 1
...
2
id: 2 2
...
id: 4 4
但是我分配的值仅限于您传递给您创建的所有线程的1,2,3。。。所以每一个都有一个指向
i
的指针,当它们解引用该指针以读取i
的值时,它们读取的是当时发生的任何i
如果您想在创建
pthread\u
时传递i
的值,我建议malloc()
一小块内存,将i
复制到它,并将malloced内容传递给线程(线程可以读取它和free()
内存。或为创建的每个线程在不同位置提供i
副本的任何其他方法。您将&i
传递给您创建的所有线程…因此每个线程都有一个指向i
的指针,当它们取消引用该指针以读取i
的值时,它们读取的内容就是i代码>正好在当时
如果您想在创建pthread\u
时传递i
的值,我建议malloc()
一小块内存,将i
复制到它,并将malloced内容传递给线程(线程可以读取它和free()
内存。或者为创建的每个线程在不同位置提供i
副本的任何其他方法。似乎这是唯一的选择…任何使用局部变量的方法,我的意思是静态变量如果您确切地知道要创建多少线程,那么您可以定义一个i\u的静态数组ad
,为每个要创建的线程设置一个条目,在创建之前为每个线程设置条目,并将该条目的地址传递给该线程。@Lonewolf:由于您似乎事先知道线程的数量,只需定义int is[NO_receivers]
并通过执行is[i]在循环中初始化它即可=i;
并将&is[i]
传递给pthread\u create()
。由于i
只是一个int
值,因此可以传递(void*)i
,并在线程函数中将其回传:id=(int)val;
。如果您担心在强制转换中丢失信息,那么对i
和val
使用intptr\u t
而不是int
,因为intptr\u t
保证能够在void*
中来回转换而不会丢失。这似乎是唯一的选择……任何方法都可以做到这一点局部变量,我的意思是静态变量如果你确切地知道要创建多少线程,那么你可以为线程定义一个静态数组i\u
,为每个要创建的线程定义一个条目,在创建它之前为每个线程设置条目,并将该条目的地址传递给线程。@Lonewolf:你似乎知道预先定义int为[NO_receivers]
的线程数,并通过执行is[i]=i;
在循环中初始化它,然后将&is[i]
传递到pthread\u create()
。由于i
只是一个int
,因此可以传递(void*)i
,并在线程函数中将其返回:id=(int)val;
。如果您担心在强制转换中丢失信息,那么对i
和val
使用intptr\u t
而不是int
,因为intptr\u t
保证能够在void*
中来回转换而不会丢失。您不会在内核空间中尝试这样做,不是吗?@alk No i它只是一个访问内核开发文件的用户程序。你不想在内核空间中这样做,是吗?@alk No它只是一个访问内核开发文件的用户程序
...
id: 1 1
...
2
id: 2 2
...
id: 4 4