描述

下面程序的输出结果是:

A::Fun

C::Do

请填空:

#include <iostream>
using namespace std;
class A {
private:
int nVal;
public:
void Fun()
{ cout << "A::Fun" << endl; }
void Do()
{ cout << "A::Do" << endl; }
};
class B:public A {
public:
virtual void Do()
{ cout << "B::Do" << endl; }
};
class C:public B {
public:
void Do( )
{ cout << "C::Do" <<endl; }
void Fun()
{ cout << "C::Fun" << endl; }
};
void Call(
// 在此处补充你的代码
         )  {
p.Fun(); p.Do();
}
int main() {
C c; Call(c);
return 0;
}

输入无输出A::Fun
C::Do样例输入

样例输出

A::Fun
C::Do

Code:

#include <iostream>
using namespace std;
class A {
private:
int nVal;
public:
void Fun()
{ cout << "A::Fun" << endl; }
void Do()
{ cout << "A::Do" << endl; }
};
class B:public A {
public:
virtual void Do()
{ cout << "B::Do" << endl; }
};
class C:public B {
public:
void Do( )
{ cout << "C::Do" <<endl; }
void Fun()
{ cout << "C::Fun" << endl; }
};
void Call(
// 在此处补充你的代码
B& p
) {
p.Fun(); p.Do();
}
int main() {
C c; Call(c);
return 0;
}

  

Analysis:

随便写了一下就提交了,没想到能过。

main中Call中的实参是C类的引用,但是根据输出的结果来看,Call函数中并不是传入C类的对象。就三个类,一个一个的试也能使出结果来。

之所以填B类的引用是因为B类中有一个虚函数Do()但是没有Fun函数,所以在Call中调用Fun函数是会调用B的基类(A类)的Fun函数。调用Do时,因为B类中有一个Do的虚函数,调用用的时候会使用到多态的机制,因为传进来的是C类的对象所以调用时调用C类中的Do函数。

最新文章

  1. Fis3的前端工程化之路[三大特性篇之声明依赖]
  2. UITableview delegate dataSource调用探究
  3. SQL查询集合合并成字符串
  4. Example to use django queryset
  5. c++的历史-异常
  6. GridLookUpEdit 简单应用
  7. iOS网络
  8. js戳和php戳时间换算
  9. getHibernateTemplate()和getSession()的区别
  10. SRM 624 Building Heights DivI 解读
  11. Android访问设置
  12. DDD理论学习系列(3)-- 限界上下文
  13. Selenium对于对话框alert,confirm,prompt的处理
  14. python netifaces模块
  15. VS2012如何调试JS
  16. java中的interface接口
  17. java servlet简述
  18. python干掉pycache
  19. Maven和Solr简单总结
  20. 倍数|计蒜客2019蓝桥杯省赛 B 组模拟赛(一)

热门文章

  1. linux 下 进程和线程的区别
  2. jgrid相关功能用法记录
  3. Informatica PowerCenter下载地址
  4. Linux - 归档和压缩
  5. Linux 命令初识
  6. Python Twisted系列教程13:使用Deferred新功能实现新客户端
  7. linux rz -e
  8. 【Dubbo学习】
  9. 关于js的keyCode
  10. key things of ARC