【问题标题】:Fix Threads to execute on certain cores [duplicate]修复线程以在某些内核上执行 [重复]
【发布时间】:2011-08-02 18:50:33
【问题描述】:

可能重复:
Bind threads to processors

在 Linux 中,是否可以修复线程以在某些内核上执行。如果可能的话,我还想知道是否可以在某个内核上独占执行一个线程,即在该线程执行时不允许任何其他线程在该内核上执行。

【问题讨论】:

  • 可能值得注意的是,调度程序的工作是以有效的方式将线程分配给 cpus。你有什么理由需要事后猜测吗?

标签: c linux pthreads


【解决方案1】:

pthread_setaffinity_np(3) 就是这样做的。

pthread_setaffinity_np() 函数设置 CPU 关联掩码 cpuset 指向的 CPU 集的线程线程。如果来电是 成功,并且线程当前未在其中一个 CPU 上运行 在 cpuset 中,然后将其迁移到其中一个 CPU。

举个例子:

cpu_set_t set;
CPU_ZERO(&set);
CPU_SET(3, &set); /* Run only on the third CPU. */

pthread_setaffinity_np(thr, CPU_SETSIZE, &set);


你也可以用sched_setaffinity(2)gettid 来做,但是手册页说:

如果您使用的是 POSIX 线程 API,则 使用 pthread_setaffinity_np(3) 而不是 sched_setaffinity()

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2019-08-29
    • 1970-01-01
    • 1970-01-01
    • 2012-07-19
    • 1970-01-01
    • 1970-01-01
    • 2011-05-28
    • 1970-01-01
    相关资源
    最近更新 更多