繁体   English   中英

新建对象并将对象的地址分配给其基类指针时,编译器会做什么?

[英]what does compiler do when new an object and assign the address of the created object to its base class pointer

例3 :(第377页)

class A {virtual void f();};
class B {virtual void f(); virtual void g();};
class C: A, B {void f();};
A* pa = new C;
B* pb = new C;
C* pc = new C;
pa->f();
pb->f();
pc->f();
pc->g()

(1)在C ++的多重继承中 ,Bjarne写道:在进入C::fthis指针必须指向C对象的开头(而不是B部分)。 但是,在编译时通常不知道pb指向的BC一部分,因此编译器无法减去常数delta(B)

为什么编译器在编译时不知道pb指向的BC一部分? 根据我的理解, pb指向的B肯定是C的一部分,因为我们new CC继承自B

B* pb = new B; 编译器是否知道pb指向的B是独立对象?

让我们对代码进行一些小的更改:

struct A {virtual void f() {}};
struct B {virtual void f() {} virtual void g() {}};

void foo(B* bp)
{
   bp->f();
}

在上述调用中,无法知道B bp指向的子类型。 可能是CD或其他。 如果您进入呼叫,您将知道B bp指向的子类型。

struct C : A, B {void f() {}};
struct D : B {void f() {}};

int main()
{
   B* pb1 = new C;
   B* pb2 = new D;

   foo(pb1);
   foo(pb2);
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM