Windows设置线程关联掩码无效
Windows SetThreadAffinityMask has no effect
我编写了一个小型测试程序,在该程序中,我尝试使用Windows API调用SetThreadAffinityMask将线程锁定到单个NUMA节点。我使用GetNumaNodeProcessorMask API调用检索节点的CPU位掩码,然后将该位掩码与GetCurrentThread返回的线程句柄一起传递给SetThreadAffinityMask。这是我代码的一个大大简化的版本:
// Inside a function called from a boost::thread
unsigned long long nodeMask = 0;
GetNumaNodeProcessorMask(1, &nodeMask);
HANDLE thread = GetCurrentThread();
SetThreadAffinityMask(thread, nodeMask);
DoWork(); // make-work function
当然,我检查API调用是否在我的代码中返回0,并且我还打印出了NUMA节点掩码,这正是我所期望的。我也遵循了其他地方给出的建议,打印出了第二次对SetThreadAffinityMask的相同调用返回的掩码,它与节点掩码匹配。
然而,当DoWork函数执行时,通过观察资源监视器,工作在所有核心之间进行了拆分,而不是只在表面上绑定到那些核心。在使用SetThreadAffinityMask时,我是否错过了任何失误?我运行的是Windows 7 Professional 64位,DoWork函数包含一个与OpenMP并行的循环,它对三个非常大的数组的元素执行操作(这些数组组合在一起仍然能够容纳在节点中)。
编辑:为了扩展David Schwartz给出的答案,在Windows上,任何使用OpenMP生成的线程都不会继承生成它们的线程的亲和力。问题在于此,而不是SetThreadAffinityMask。
是否确认其关联掩码的特定线程正在另一个numa节点的核心上运行?否则,它会按预期工作。您正在一个线程上设置处理器掩码,然后观察线程组的行为。
相关文章:
- 位移操作和位掩码未检测到重复字符
- OpenCV - 带有掩码的absdiff
- 生成前缀位掩码
- 如何从__m64值的 lsb 创建 8 位掩码?
- 如何对无符号长 int 进行位掩码?
- 删除K的背景掩码-意味着Python或C++中的集群/
- 如何在C++中优雅地处理位掩码
- 将uint64_t位掩码转换为 std::布尔数组
- 使输入二进制掩码适应 ITK 网格生成器
- 如何从 getifaddr 读取子网掩码
- 优化从子位掩码生成父位掩码
- 基于模式创建位掩码作为 constexpr
- 使用二进制掩码 C++ ITK 获取感兴趣区域
- C++中的运行时位复制(位掩码)
- 根据 IP 和掩码C++打印所有 IP
- C++设置"blank"或重置 ifstrean (ios) 的异常掩码
- OpenCV 检测带有掩码的斑点
- OPENCV:如何创建多边形形状的掩码
- 递归函数,用于使用位掩码 c++ 显示集合的所有子集
- Windows设置线程关联掩码无效