Я использую Linux Centos.
Я кодирую в c с помощью pthread и использую pthread_set_affinity . Я хочу, чтобы каждый поток работал в уникальном процессоре. Как ---
thread1 in proccessor 0
thread2 in proccessor 1
.
.
.
threadn in processor n
в настоящее время, когда я использую этот set_affinity, он запускается, но когда я увидел системный монитор, я вижу, что загрузка ЦП восьми ядер не распределяется.
КОД похож на это: *
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% 0% 2% 0% 1% 0% 0% 1%
У меня 8-ядерный ПК, и я пытаюсь запустить 8 потоков в 8 ядрах. Есть способ полностью использовать 8 ядер в этом pthread и pthread_set_affinity.