Visual C++.NET 2003
VC.NET 2003不仅带来了两个新的优化选项,它还改进了VC.NET 2002中一些优化的性能。
第一个新增选项是“/G7”,它告诉编译器对Intel Pentium 4和AMD Athlon处理器进行优化。
使用“/G7”选项编译的程序,当我们和VC.NET 2002生成的代码比较时发现,它通常能使典型的程序的运行速度提高5到10个百分点,如果使用了大量浮点代码甚至能提高10到15个百分点。而提高的优化程度可能很高也可能较低,在一些使用最新CPU和“/G7”选项的测试中,甚至提高了20%的性能。
使用“/G7”选项不代表生成的代码只能运行在Intel Pentium 4和AMD Athlon处理器上。这些代码仍可以运行在老的CPU上,只是在性能表现上可能有“小小的惩罚”。另外,我们观察到一些程序使用“/G7”后在AMD Athlon上运行的比用Intel Pentium 4更慢。
当没使用“/Gx”选项时,编译器会默认使用“/GB”选项,此时为“blended”优化模式。在VC.NET 2002和VC.NET 2003中,“/GB”代表“/G6”,即为Intel Pentium Pro, Pentium II, Pentium III处理器优化。
这儿有一个例子,它展示了做与常整数乘法时使用Pentium 4和“/G7”的优化效果,下面是源代码:
|
当使用“/G6”时,生成了目标代码:
|
当使用“/G7”时,生成了更快(可惜更长)的代码,它没用imul(乘)指令,在Pentium 4上执行只需要14个周期。目标代码如下:
|
第二个优化选项是“/arch:[argument]”,用它可对SSE或SSE2优化,生成使用Streaming SIMD Extensions(SSE)和Streaming SIMD Extensions 2(SSE2)指令集的程序。当使用“/arch:SSE”选项时,目标代码只能运行在支持SSE指令(如:CMOV,FCOMI,FCOMIP,FUCOMI,FUCOMIP)的CPU上。当使用“/arch:SSE2”选项时,目标代码只能运行在支持SSE2指令集的CPU上。
相比于“/G7”,使用了SSE或SSE2优化的程序,一般能减少2-3%的运行时间,个别测试中甚至能减少5%的运行时间。
使用“/arch:SSE”可得到以下效果:
1、在使用单精度浮点数时,使用SSE指令对其处理。
2、使用CMOV指令,它最早被Pentium Pro支持。
3、使用FCOMI,FCOMIP,FUCOMI,FUCOMIP指令,它们也是最早被Pentium Pro支持的。
使用“/arch:SSE2”的话,可以得到所有“/arch:SSE”选项的效果,另外还有以下几个效果:
1、在使用双精度浮点数时,使用SSE2指令对其处理。
2、使SSE2指令集做64位切换。(原文:Making use of SSE2 instructions for 64-bit shifts)
还有其它的好处,在同时使用“/arch:SSE”或“/arch:SSE2” 和“/GL”(全程优化)选项选项时,编译器会对浮点参数和浮点返回值做函数调用规则优化。
上面说的几点优化特性已经包括于VC.NET 2003里了。另外还有一点就是能消除“死参数”--从没被用过的参数。比如:
|
在函数f1()中,第二个参数从没被使用过。当我们用“/GL”(全程优化)选项时,编译器将产生如下目标代码来调用f1():
|
在这个例子里,变量“n”从没被运算,只有两个参数被f1()使用,所以只传递那两个参数(并且它们是从寄存器传过去的,这比使用栈传更快)。另外,编译这个例子时要禁止内联(inlining),否则函数f1()就不存在了,而直接给m赋予值7。
| 共2页: 1 [2] 下一页 | ||
|
|
|||
| · 51CTO主编推荐经典专题 · RAID——磁盘阵列基础 · 充电计划之热门IT认证.. · 51CTO技术自测 挑战自.. · CISSP认证成长之路 · AMD Phenom三核处理器.. · 国际文档格式标准开战 · 2007年互联网大会 |
· 我是黑客我怕谁——讲.. · ARP攻击防范与解决方案 · Solaris 10 配置管理 · Solaris基础知识入门 · RIP路由协议专栏 · MPLS路由协议专栏 · OSPF路由协议专栏 · 思科路由器产品 |
||
|
|||
| · Java基础教程 · VPN技术 · ARP攻击防范与解决方案 · SQL Server 2005全解 · SOA 面向服务架构 · SQL Server 2005全解 · Java编程开发手册 · RAID——磁盘阵列基础 |
· 三层交换技术专题 · SQL Server入门到精通 · Windows Server 2003企.. · Windows远程桌面应用 · C#技术开发指南 · VPN技术 · Solaris 10 配置管理 · C#技术开发指南 |
||
|
|||
| · ARP攻击防范与解决方案 · VPN技术 · SQL Server 2005全解 · Java基础教程 · SQL Server入门到精通 · SQL Server 2005全解 · SOA 面向服务架构 · Java编程开发手册 |
· C#技术开发指南 · 三层交换技术专题 · C#技术开发指南 · Windows远程桌面应用 · RAID——磁盘阵列基础 · Windows Server 2003企.. · 邮件服务器专题 · wimax技术与趋势 |
||
| ·DB2 Viper快速入门 ·DB2 9数据库的镜像分割与.. |
·将XML应用程序从DB2 8.x.. ·DB2 9中的pureXML:如何.. |
| ·服务器中的“傻瓜机”在.. ·盖茨也喜欢登录Youtube看.. |
· · |
| ·拯救系统管理员 ·美国选民:我为什么选布什 |
·VMware公司中文命名挑战赛 ·我们真缺乏创新吗? |
| ·J0ker的CISSP之路:复习-.. ·J0ker的CISSP之路:复习-I.. |
·9月第3周安全回顾 内网安.. ·教你几招识别和防御Web网.. |
| · NGN:下一代网络 · 网络访问中断大排查 · FTTx光纤接入 |
· 教你使用Anti ARP Sniff.. · 网络嗅探教程:使用Snif.. · 常见病毒手工清除方法大.. |
| · C++是垃圾语言?! · 2007年IT界七大抄袭事件 · Java实用开发全集 |
· 解析Ajax开发框架 走进A.. · 基于Google Maps与Ajax.. · 基于Google Maps与Ajax.. |
| · 热门 IT 培训认证官方资.. · Ubuntu 中文开源频道 · Solaris基础知识入门 |
· 费力不讨好 数据中心主.. · AMD Phenom三核处理器解.. · 51CTO主编推荐经典专题 |
| · 甲骨文Oracle 11g正式发.. · Oracle数据库开发之PL/S.. · Oracle数据库开发基础教.. |
· 存储2006,一个并购的大.. · IDC宣布浪潮蝉联存储市.. · 双机热备技术 |