• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

Obfuscated C++

发布: 2007-7-01 20:40 | 作者: admin | 来源: | 查看: 11次 | 进入软件测试论坛讨论

领测软件测试网

你能预测下面这个程序的输出结果吗:

#include <iostream> using namespace std; namespace N { void g(int) { cout << "g(int)\n"; } }; using namespace N; namespace N { void g(char){ cout << "g(char)\n"; } }; int main(){ g(´x´); return 0; }它的输出为:g(char).这个问题的关键在于g(char)的声明是否在引用的范围内.的确在这范围内!因为"using namespace N"为引用带入了N命名空间的所有可视的申明,而不止是在using命令出现的地方(也在随后出现的引用的地方).这也就意味着g(char)的声明在g(´x´)的呼叫范围之内.由于g(char)比g(int)更适合,所以g(char)被呼叫.那么,下面这个程序的结果又是什么呢?#include <iostream> using namespace std; struct C; struct D { void operator*(D) { cout << "one\n"; } } C;   struct E { void operator*(E) { cout << "two\n"; } } F; struct F; int main(){ C* C; F* F; return 0; }这个问题的关键在于main()函数中前2个语句的含义.依照语法,这些语句是指针的声明.空白起了迷惑作用.每条语句中,变量(C or F)即被声明为一个类,又作为一个全局对象名而存在.在这种情形下,忽略声明的先后顺序,对象名隐藏了类名.而这个类名只能用一复杂语句(e.g..struct C* C;)引用.每一条语句只不过是operator*的应用.我们可以用以下语句重写:int main(){ C.operator*(C); // Invokes D::operator*(D) F.operator*(F); // Invokes E::operator*(E) return 0; }所以我们的程序输出为:.netwo

延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备2023014753号-2
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网