当我运行多线程代码时,系统(Linux)有时会将线程从一个处理器移动到另一个处理器。由于我有与处理器一样多的线程,它会无缘无故地使缓存失效,并且会混淆我的跟踪活动。
您知道如何将线程绑定到处理器吗?为什么系统要这样做?
Use sched_setaffinity (这是 Linux 特定的).
为什么调度程序要在不同处理器之间切换线程?好吧,想象一下您的线程上次在处理器 1 上运行,当前正在等待再次调度执行。与此同时,另一个线程当前正在处理器 1 上运行,但处理器 2 空闲。在这种情况下,调度程序将线程切换到处理器 2 是合理的。但是,复杂的调度程序会尽量避免不必要地在处理器之间“弹跳”线程。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)