趋势科技笔试【6】
2012-10-05 21:22
155 查看
题目:请问下面的程序输出是什么?
结果:
解释:
1. 为什么构造函数和析构函数能够分别调用自己的f(),而不是调用多态产生的实际类型的呢?
答:由于CA的构造函数构造的是CA类型的,因此在CA类型的构造函数中调用f(),只会调用CA自己的;析构函数与此同理。
2. func()的调用为什么会输出this is B?
答:这就是多态的用途。由于有virtual的作用,CA* p指针看到CA里面的func()函数会调用f(),而看CA里面的f()是在虚函数表中的,直接指向最新的实际类型的f(),也就是调用实际类型CB的f(),因此输出this is B.
要调用基类的函数,可以用基类CA::来限定。
// test3.cpp : 定义控制台应用程序的入口点。 // #include "stdafx.h" #include <iostream> using namespace std; class CA { public: CA(){cout << "ca ....."<<endl;f();}; virtual ~CA(){f();}; void func(){f();}; virtual void f(){cout << "this is A" <<endl;}; }; class CB:public CA { public: CB(){cout << "cb....." <<endl;f();}; virtual ~CB(){f();}; void func(){f();}; virtual void f(){cout << "this is B" <<endl;}; }; int _tmain(int argc, _TCHAR* argv[]) { CA* p = new CB; cout << "============================="<<endl; p->func(); p->CA::func(); p->CA::f(); cout << "============================="<<endl; delete p; getchar(); return 0; }
结果:
解释:
1. 为什么构造函数和析构函数能够分别调用自己的f(),而不是调用多态产生的实际类型的呢?
答:由于CA的构造函数构造的是CA类型的,因此在CA类型的构造函数中调用f(),只会调用CA自己的;析构函数与此同理。
2. func()的调用为什么会输出this is B?
答:这就是多态的用途。由于有virtual的作用,CA* p指针看到CA里面的func()函数会调用f(),而看CA里面的f()是在虚函数表中的,直接指向最新的实际类型的f(),也就是调用实际类型CB的f(),因此输出this is B.
要调用基类的函数,可以用基类CA::来限定。
相关文章推荐
- C++经典笔试题及参考答案-趋势科技
- 【2014校招】趋势科技笔试
- 趋势科技2014校园招聘笔试题
- 哥的传奇笔试经历-趋势科技、绿盟科技、搜狐、百度
- 趋势科技笔试题
- 趋势科技笔试面试经历zz
- 2012.9.20以来的笔试面试(中兴,百度,趋势科技等)
- 趋势科技笔试题
- 趋势科技2011校招笔试题+答案解析
- 趋势科技2014年暑期实习生笔试题
- 趋势科技笔试题1
- 趋势科技笔试题
- C++经典笔试题及参考答案-趋势科技
- 趋势科技2015笔试题-南京
- 2014年趋势科技笔试+面试(实习生)
- 趋势科技几道笔试题
- C++经典笔试题及参考答案-趋势科技
- 2015趋势科技校招笔试面试
- 趋势科技2011校招笔试题+答案解析
- 2015年趋势科技笔试A卷