我编码在C与并行线程和使用pthread_set_affinity。我希望看到每个线程独特processor.Like运行---
thread1 in proccessor 0
thread2 in proccessor 1
.
.
.
threadn in processor n
目前当我使用这个set_affinity运行,但是当我看到系统监视器,我看到八核心的CPU利用率没有分配。
CODE就是这样 ::
if(for thread 1)
{
pthread_attr_init(&pta);
CPU_SET(0,&cpuset);
pthread_setaffinity_np(thread1, sizeof(cpu_set_t), &cpuset);
pthread_create(&thread1,&pta,&sendimsg,(void*)&message);
pthread_join(thread1,NULL);
printf("User for Thread One : %d\n",numb.fir);
pthread_attr_destroy(&pta);
CPU_ZERO(&cpuset);
}
else if(for thread 2)
{
pthread_attr_init(&pra);
CPU_SET(1,&cpuset1);
pthread_setaffinity_np(thread2, sizeof(cpu_set_t), &cpuset);
pthread_create(&thread2,&pra,&sendimsg,(void*)&message);
pthread_join(thread2,NULL);
printf("User for Thread Two : %d\n",numb.sec);
pthread_attr_destroy(&pra);
CPU_ZERO(&cpuset1);
}
for eight thread that way.
注:螺纹的分布式分配了类似20 20 20 20 ... 20
的比例是这样的方式
10%1我有8个核心的电脑,并试图在8核心运行8个线程。有没有一种方法可以完全利用8核心在这个pthread和p thread_set_affinity。
+0
可能某些线程是cpu密集型的,某些线程正在休眠或正在等待互斥锁等待被阻止的IO调用。 –
+0
也许你可以展示一些代码,然后有人可能会帮助更多的东西而不是普遍的假设。 –
+0
如果线程正在使用它们之间的公共数据,实际上这可能不是一个好主意,因为那样的话数据必须在缓存之间被复制,而不是只在一个缓存中。 –