[局部探究][C++]虚函数与成员函数调用行为与成员指针

  • 构造函数与析构函数一个重要的职能或特点是类型确定,即进入函数时,先修改虚表指针,所以在其中对虚函数的调用不是运行时确定的(编译器的实现是直接调用,即不通过虚表)
  • 成员函数指针形式的调用是动态的(TODO 成员函数指针的实现)
  • 带域的调用形式是编译期确定的
#include <iostream>
using namespace std;

class A {
 public:
  int i;
  A() { foo(); }
  ~A() { foo(); }
  void func() { cout << "A::func()" << endl; }
  virtual void f() { cout << "A::f()" << endl; }
  virtual void foo() { cout << "A::foo()" << endl; }
  virtual void foooo() {
    cout << "A::foooo()" << endl;
    f();
    A::f();
  }
};
class B : public A {
 public:
  B() { foo(); }
  ~B() { foo(); }
  void f() { cout << "B::f()" << endl; }
  void foo() { cout << "B::foo()" << endl; }
  void foooo() {
    cout << "B::foooo()" << endl;
    f();
    A::f();
  }
};
int main() {
  B b;                               //|A::foo() B::foo()
  B *bp = &b;                        //|
  A *ap = &b;                        //|
  ap->foo();                         //|B::foo() 
  (*ap).foo();                       //|B::foo() 
  ap->A::foo();                      //|A::foo()
  void (A::*Afoop)() = &A::foo;      //|
  (ap->*Afoop)();                    //|B::foo()
  //void (A::*Afuncp)() = &A::func;  //|
  //(bp->*Afuncp)();                 //|
  printf("%08x\n", &B::f);           //|...
  printf("%08x\n", &B::func);        //|...
  //cout << &B::func << endl;        //|
  ap->foooo();                       //|B::foooo() B::f() A::f()
  ap->A::foooo();                    //|A::foooo() B::f() A::f()
  return 0;                          //|B::foo() A::foo()
}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值