1

我在面试中被问到这个问题。以下程序创建了多少个虚拟表,每种情况下的输出是什么。

#include <iostream> 
using namespace std;
class A
{
 virtual void func1()
 {
  cout << "0 " <<endl;
 }

 virtual void func2()
 {
  cout << "1 " <<endl;
 }
};

 class B:Public A
 {
  void func1()
  {
   cout << "2" <<endl;
  }
 };

class C:public B
{
 virtual void func2()
 {
  cout << "3" <<endl;
 }
}

int main()
{
A* objA;

B objB ;
C objC ;

//case1:
objA = &objB;
objA->func1();
//case2:
objA = &objC;
objA->func2();
objA->func1();
return 0;
}

我对 B 类感到困惑。它是否为 B 类创建了一个 vtable?在这种情况下将调用哪个函数。有人可以解释一下吗?

4

2 回答 2

1

看评论

// I'll pretend you have a #include <stdio.h> here

class A
{
 virtual void func1()
 {
  print 0; // error!!  I'll pretend this was puts("0");
 }

 virtual void func2()
 {
  print1;  // error!!  I'll pretend this was puts("1"); 
 }
};

// there is a virtual table for class A. (for two virtual methods)


 class B:Public A
 {
  void func1()
  {
   print2; // error!!  I'll pretend this was puts("2"); 
  }
 };

// there is a virtual table for class B. (for two virtual methods)


class C:public B
{
 virtual void func2()
 {
  print 3; // error!!  I'll pretend this was puts("3"); 
 }
}

// there is a virtual table for class C. (for two virtual methods)


int main()
{
A objA;
B* objB = new B();

C* objC = new C();

//case1:
objA = &objB;   // error!! left side of type A right side of type B**
objA->func1();  // error!!  operator -> on non pointer

//case2:
objA = &objC;  // error!! left side of type A right side of type B**
objA->func2(); // error!!  operator -> on non pointer
objA->func1(); // error!!  operator -> on non pointer
return 0;
}

// nothing is printed

由于您编辑了 OP 代码,因此这是新版本代码的答案。看评论:

#include <iostream> 
using namespace std;
class A
{
 virtual void func1()
 {
  cout << "0 " <<endl; // it's ok, but is the space supposed to be there?
 }

 virtual void func2()
 {
  cout << "1 " <<endl; // it's ok, but is the space supposed to be there?
 }
};
// there is a virtual table for class A. (for two virtual methods)

 class B:Public A  // error!! I'll pretend Public was public (lowercase)
 {
  void func1()
  {
   cout << "2" <<endl; // it's ok, but here there's no space, is that correct?
  }
 };
// there is a virtual table for class B. (for two virtual methods)

class C:public B
{
 virtual void func2()
 {
  cout << "3" <<endl; // it's ok, but here there's no space, is that correct?
 }
}
// there is a virtual table for class C. (for two virtual methods)

int main()
{
A* objA;

B objB ;
C objC ;

//case1:
objA = &objB;
objA->func1(); // outputs (to stdout) a '2' (two) and whatever a 
               // newline is on your system (could be '\r' or '\n' or both
               // or in fact anything your platform defines a newline is)
               // stdout is then flushed.
//case2:
objA = &objC;
objA->func2(); // outputs (to stdout) a '3' (three) and whatever a 
               // newline is on your system (could be '\r' or '\n' or both
               // or in fact anything your platform defines a newline is)
               // stdout is then flushed.

objA->func1(); // outputs (to stdout) a '2' (two) and whatever a 
               // newline is on your system (could be '\r' or '\n' or both
               // or in fact anything your platform defines a newline is)
               // stdout is then flushed.
return 0;
}
// the output is '2' <newline> '3' <newline> '2' <newline> 
// where the actual character(s) for <newline> are platform dependent  
于 2012-09-21T07:07:49.047 回答
0

B 类的实例也是 A 类的实例。您的 B 类调用 A 类的构造函数,如果 B 没有从 A 覆盖 func1(),则 B 具有虚拟 func2() 和 A 的 func1() 覆盖。

于 2012-09-21T05:31:56.487 回答