Linux屏蔽物理CPU,在Linux中使用pthread中的可用物理CPU内核

我编码在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

如果线程正在使用它们之间的公共数据,实际上这可能不是一个好主意,因为那样的话数据必须在缓存之间被复制,而不是只在一个缓存中。 –

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值