1.什么是超线程技术
2.超线程技术的产生原因
CPU发展到今天,其整体速度虽然越来越快,内部的执行单元却越来越得不到充分的利用.为什么呢?原来NetBurst架构的奔腾4在设计结构上就每次只能处理一个线程,而与此同时我们的电脑需要同步执行的任务却在不断增加,而且花在各线程之间切换等待的时间太多,处理器的应用效率自然也就降低了。
长期以来,CPU生产商为了提高CPU的性能,通常做法是提高CPU的时钟频率、增加缓存容量、晶体管数量以及指令集来提升其性能.这些方法的副作用就是会增加处理器的功耗,而且往往会受到制造工艺上的限制以及成本过高的制约.CPU要想取得更好的表现,拥有更快的处理速度,就得需要更大的供电量,更强劲的散热条件.2005年,英特尔取消了生产4.0GHz的“Te-jas”单核处理器.因为他们发现,要想达到这个频率,它的驱动功率必须要达到100W.不仅如此,要保证它正常的运行还要有温度的控制,需要更大的散热器.要是在不过多增加硬件投入的情况下,处理器就能够充分利用现有的强劲物理单元同步执行多线程来增强性能,那该多好?因此,Intel采用另一个思路去提高CPU的性能,让CPU可以同时执行多重线程,就能够让CPU发挥更大效率,即超线程技术。
也正是由于通过不高的代价,就能带来极大的性能提升,超线程技术倍受Intel的青睐,并被予以大力宣传。
3.超线程技术的工作原理
超线程技术的工作原理是在每个时钟周期内完成更多工作,一个支持超线程(HT)技术的处理器使当前的操作系统和应用可以看到两个虚拟处理器,该处理器可以同时处理两组任务,充分利用闲置资源,并可在相同时间内完成更多工作。
在处理多个线程的过程中,多线程处理器内部的每个逻辑处理器均可以单独对中断做出响应,当第一个逻辑处理器跟踪一个软件线程时,第二个逻辑处理器也开始对另外一个软件线程进行跟踪和处理了.另外,为了避免CPU处理资源冲突,负责处理第二个线程的那个逻辑处理器,其使用的是仅是运行第一个线程时被暂时闲置的处理单元.例如:当一个逻辑处理器在执行浮点运算(使用处理器的浮点运算单元)时,另一个逻辑处理器可以执行加法运算(使用处理器的整数运算单元).这样做,无疑大大提高了处理器内部处理单元的利用率和相应的数据、指令的吞吐能力。
4.超线程技术的优缺点
1.优点
(1)投入少,物美价廉.由于这项技术是将一个处理器模拟成两个使用,从而在增加极少投入的情况下就能够提高性能.对于操作系统来说,它又像真的拥有两个物理处理器一样工作,从而让两个程序或一个程序的两个线程,能够在单处理器上同时执行.由于减少了在线程之间的切换,提高了执行单元的利用率,从而使处理器实际使用效果得到极大的改善。
(2)超线程在Web服务、SQL数据库等很多服务器领域的应用中表现优异.在2001年的时候,IBM就推出了它的第一款双核Power4处理器.IBM当时是用在了它的RISC服务器中,服务器的性能得到了很大的提高.
(3)在某些支持多线程的软件应用上能够得到3O左右的性能提升,如3Dsmax、Maya、Of—rice、Photoshop等.在今后的软件开发中,支持多线程应用的软件定会蓬勃发展,大多数主流软件都会利用到超线程.因为无论是硬件厂商或软件厂商都会利用新技术来巩固自己的市场地位.
(4)WindowsXP已经针对其作出优化,在运行多个不支持多线程的程序时,性能也可能会获得提高.即便带来损失,也会显得比较轻微.
(5)主流的桌面芯片组基本都已可以支持超线程,无需额外的花费.
(6)目前在高端的PentiumEE和一部分Xe-on上也支持超线程技术.在支持超线程的处理器的机器上,支持多CPU的Windows会认出两个CPU.而在支持双内核处理的机器上,Windows也会认出两个CPU,在支持超线程双内核的处理器上,Windows会认出四个CPU。
2.缺点
(1)英特尔P4超线程有两个运行模式,Sin-gleTaskMode(单任务模式)及MuhiTaskMode(多任务模式),当程序不支持Multi-Processing(多处理器作业)时,系统会停止其中一个逻辑CPU的运行,把资源集中于单个逻辑CPU中,让单线程程序不会因其中一个逻辑CPU闲置而减低性能,但由于被停止运行的逻辑CPU还是会等待工作,占用一定的资源,因此Hyper-Thread-ingCPU运行SingleTaskMode程序模式时,有可能达不到不带超线程功能的CPU性能。
(2)现在只有WindowsXP才能支持超线程技术,所以在操作系统上受到很大的限制.虽然微软公司新推出的WindowsVISTA系统也支持该技术,但是VISTA系统对计算机硬件及软件的要求很高,所以安装的成本较大。
(3)缺乏大量普通应用软件的支持,性能因此得不到充分体现。