草庐IT

c++ - 编译时消除虚拟表?

假设我有这个层次结构:classSuper{public:virtualvoidbar();};classSub:publicSuper{public:virtualvoidbar()override;};有没有办法让我在使用virtual关键字的情况下避免vtables?(好奇心)我读过一些关于编译器优化的文章,当对象在编译期间已知时,它会消除vtables,我不太确定,在谷歌上搜索了一段时间,但找不到任何答案,这是否意味着这些?Subsb;sb.bar();//avoidsvtable?Super&sr=sb;sr.bar();//avoidsvtable?Super*srp=&s

c++ - 在父类(super class)中调用抽象方法,并在C++中的子类中实现它?

在Java中,可以编写具有未实现的抽象方法和调用抽象方法的非抽象方法的抽象父类(superclass)。然后在子类中实现了抽象方法。当您创建子类的实例时,父类(superclass)使用子类中的实现。我如何在C++中完成此操作?这就是我的意思,但是在Java中:父类(superclass).javapublicabstractclassSuperClass{publicSuperClass(){method();}privatevoidmethod(){unimplementedMethod();}protectedabstractvoidunimplementedMethod();}

c++ - 用父类(super class)的实例覆盖子类的实例

为了解决问题(实际上是在Ada中),我想出了以下代码。为什么它是合法的?classSuperclass{public:virtualvoidAnnounce(){printf("Iamthesuperclass\n");}};classSubclass:publicSuperclass{public:voidAnnounce(){printf("Iamthesubclass\n");}};intmain(){Superclassosuper;Subclassosub;Superclass*p=&osub;*p=osuper;osub.Announce();return0;}在main(

c++ - 在没有虚方法或父类(super class)的类中,假设(第一个成员变量的地址)== this 是否安全?

我创建了一个私有(private)API,它假定类中第一个成员对象的地址与类的this指针相同......这样成员对象就可以简单地派生出指向该对象的指针它是的成员,而不必显式存储指针。鉴于我愿意确保容器类不会从任何父类(superclass)继承,不会有任何虚拟方法,并且执行此技巧的成员对象将是声明的第一个成员对象,将该假设对任何C++编译器都有效,还是我需要使用offsetof()运算符(或类似运算符)来保证正确性?换句话说,下面的代码在g++下实现了我所期望的,但它能在任何地方运行吗?classMyContainer{public:MyContainer(){}~MyContain

c++ - Vector of pointer to objects,需要vector的深拷贝,但是对象是继承对象的基础

我想要一个包含指向对象指针的vector的深层拷贝,但对象可以是C或B。我知道混淆(我解释它的方式),让我举例说明。classA{A(constA©me){}voidUnableToInstantiateMeBecauseOf()=0;};classB{B(constB©me):A(copyme){}};classC{C(constC©me):A(copyme){}};std::vector*CreateDeepCopy(std::vector&list){std::vector*outList=newstd::vector();for(std::vector:

c++ - 子类如何使用与子类相同的方法名调用父类(super class)的方法?

#includeusingnamespacestd;classPerson{public:voidsing();};classChild:publicPerson{public:voidsing();};Person::sing(){cout 最佳答案 suzie.Person::sing(); 关于c++-子类如何使用与子类相同的方法名调用父类(superclass)的方法?,我们在StackOverflow上找到一个类似的问题: https://stack

c++ - 从父类(super class)调用子类中的虚函数

我知道这个问题一定被无数次问过,但我搜索了以前的问题,似乎什么也没有。它是关于C++中的继承和虚函数。我在从父类(superclass)的子类中调用虚函数时遇到问题。我举个例子。从三个相互继承的类开始。classA{voidfoo(){bar()}virtualvoidbar(){}};classB:publicA{virtualvoidbar(){}};classC:publicB{virtualvoidbar(){//dosomething}};现在我想要一个声明为B*但实例化为C*的变量。B*myObject=newC();myObject->foo();当我这样做并在myObj

c++使用va_arg调用父类(super class)构造函数

我有一个基类,其中包含一个带有可变参数列表的构造函数:classSuper{public:Super(intnum,...);...}现在,在我的子类构造函数中,我需要以某种方式调用这个父类(superclass)构造函数,但我该怎么做呢?通常的事情自然是行不通的:classSub{public:Sub(intnum,...):Super(???){...}...}那么我应该输入什么而不是???我确实有另一个接受vector的构造函数,但有这样一个构造函数是客户的直接要求。 最佳答案 与任何变量函数一样,也始终提供列表版本:void

c++ - 调用子覆盖时始终调用父类(super class)虚函数

我有这样的结构:classA{public:virtualvoidfunc(inta){cout现在,在95%的情况下,当我从A继承时,我会覆盖func,在100%的情况下,我应该在执行任何其他操作之前调用A::func();?我怎样才能防止手动编写这个。有时我什至忘记在子类中调用A::func();并得到运行时错误、抛出等。 最佳答案 NVIpattern怎么样??classA{public:voidfunc(inta){cout 关于c++-调用子覆盖时始终调用父类(supercla

c++ - c++ 中是否有任何类是所有类的父类(super class)?

像javaJava.lang.Object是所有类的父类(superclass)所以在C++中是否有任何类像对象? 最佳答案 不,没有。在C++中,您为使用的东西付费,而不是更多。你可以有void*可以指向任何东西,或者如果有意义的话,写你自己的基类。 关于c++-c++中是否有任何类是所有类的父类(superclass)?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/1831