1.默认情况下,Windows Vista在给线程分配处理器时,使用软关联。意思是如果其他因素都一样,系统将使线程在上一次运行的处理器上运行。让线程始终在同一个处理器上运行有助于重用仍在处理器高速缓存中的数据。
2.有一种称为NUMA的计算机体系结构,结构的计算机由多个系统板组成,每个系统版都有自己的CPU和内存块。任何线程都可以在这些CPU中任何一个上运行。如果CPU需要访问其他系统板上的内存,性能会下降的厉害。为了支持这种体系结构,Windows Vista允许我们设置进程和线程的关联性。也就是说,我们可以控制CPU让哪些CPU运行特定的线程。这称为硬关联。
3.默认情况下,系统可以将任何CPU调度给任何线程使用。如果要限制某些线程只在可用CPU的一个子集上运行,则可以调用SetProcessAffinityMask(HANDLE hProcess, DWORD_PTR dwProcessAffinityMask),第二个参数代表线程可以在哪些CPU上运行。例如传入0x00000005意味着这个进程中的线程可以在CPU0和CPU2上运行,但是不能在CPU1和CPU3~31上运行。
4.请注意,子进程将继承进程关联性。此外,我们还可以使用作业内核对象来限制一组进程只在一组CPU上运行。
5.可以通过调用SetThreadAffinityMask分别设置各线程的关联性掩码。
6.当一个x86系统启动时,系统将执行代码,检查主机上的哪个CPU存在著名的Pentium浮点bug。系统必须对每个CPU做这项检查。检查的方法是,将一个线程的关联性设置为该CPU,执行可能会出错的除法操作,然后比较结果是否与已知正确的结果相符。随后再采用同样的步骤检查下一个CPU,依次类推。
7.在大多数环境里,改变线程的关联性,将妨碍调度程序的这种能力,下面给出一个例子:
8.要给线程设置一个理想的CPU(也允许系统将它移到另一个空闲的CPU),可以调用SetThreadIdealProcessor(HANDLE hThread, DWORD dwIdealProcessor),dwIdealProcessor不是位掩码,它是一个0到31/63之间的整数,表示线程希望设置的CPU。可以传入MAXIMUN_PROCESSORS值(在WinNT.h中定义,32位操作系统中定义为32,64位操作系统中定义为64),表示线程没有理想的CPU。
9.当Windows Vista在x86计算机上启动时,我们可以限制系统将使用的CPU数量(修改启动配置数据 BCD)。