首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

空基类是否应该影响派生类的布局?

空基类是否应该影响派生类的布局?

空基类是指不包含任何数据成员的基类,它的主要作用是为了实现代码的复用和多态性。在C++中,空基类不会影响派生类的布局,因为它不包含任何数据成员,也没有虚函数。

然而,在某些情况下,空基类可能会影响派生类的布局。例如,如果派生类继承了多个基类,并且这些基类中有空基类,那么空基类可能会导致派生类的布局发生变化。这是因为空基类可能会被视为一个虚基类,从而导致派生类的布局发生变化。

此外,如果派生类继承了多个基类,并且这些基类中有空基类,那么空基类可能会导致派生类的布局发生变化。这是因为空基类可能会被视为一个虚基类,从而导致派生类的布局发生变化。

总之,空基类不会影响派生类的布局,但在某些情况下,空基类可能会导致派生类的布局发生变化。在编写代码时,应该注意这些问题,以确保代码的正确性和可维护性。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

C++中派生类对基类成员的访问形式

C++中派生类对基类成员的访问形式主要有以下两种: 1、内部访问:由派生类中新增成员对基类继承来的成员的访问。 2、对象访问:在派生类外部,通过派生类的对象对从基类继承来的成员的访问。...今天给大家介绍在3中继承方式下,派生类对基类成员的访问规则。...基类的private成员在私有派生类中是不可直接访问的,所以无论是派生类的成员还是通过派生类的对象,都无法直接访问从基类继承来的private成员,但是可以通过基类提供的public成员函数间接访问。...基类的private成员在私有派生类中是不可直接访问的,所以无论是派生类成员还是派生类的对象,都无法直接访问从基类继承来的private成员,但是可以通过基类提供的public成员函数直接访问它们。...基类的private成员在私有派生类中是不可直接访问的,所以无论是派生类成员还是通过派生类的对象,都无法直接访问基类中的private成员。

2.4K70
  • 派生类对基类中虚函数和非虚函数的继承效果

    “强制实现”,也就是只要是父类指针调用普通函数,那就是父类的普通函数 而虚函数的作用,主要是为了让父类指针可以调用子类的函数,这种是在运行时才决定调用哪个函数 1、虚函数:   C++的虚函数主要作用是...“运行时多态”,父类中提供虚函数的实现,为子类提供默认的函数实现。...子类可以重写父类的虚函数实现子类的特殊化。 2、纯虚函数:   C++中包含纯虚函数的类,被称为是“抽象类”。抽象类不能使用new出对象,只有实现了这个纯虚函数的子类才能new出对象。   ...3、普通函数:   普通函数是静态编译的,没有运行时多态,只会根据指针或引用的“字面值”类对象,调用自己的普通函数。   普通函数是父类为子类提供的“强制实现”。   ...因此,在继承关系中,子类不应该重写父类的普通函数,因为函数的调用至于类对象的字面值有关。 参考链接

    9210

    C++:43---派生类向基类转换、静态动态的类变量

    二、转换的本质 派生类可以转换为基类的本质是: ①为什么派生类可以转换为基类:派生类从基类而来,因此派生类中包含了基类的方法和成员。...此时基类可以通过指针或引用指向派生类(相当于将派生类从基类中继承的那部分方法和成员绑定到基类上了,相当于派生类被截断了),然后基类就可以将派生类假装是一个基类对象来使用(调用其中的成员/方法) ②为什么基类不能转换为派生类...如果将一个基类对象绑定到派生类的指针/引用上,此时派生类通过指针/引用访问自己新定义的成员/方法时,发现找不到(因此不能将基类转换为派生类) 例如:下面B继承于A,子类继承于父类,同时为父类的成员开辟了空间...三、继承方式对类型转换的影响 遵循下面3个规则: 假设B继承于A ①只有当B公有地继承A时,用户代码才能使用派生类向基类转换;如果B是受保护的/私有的继承于A,则不能使用派生类向基类转换 因为保护或者私有继承...//假设B公有继承于A A *a; B b; a = &b; //将派生类转换为基类,正确 B *p = a; //将基类再转换为派生类,错误 五、类静态类型/类动态类型 在上面我们介绍过,基类的指针或引用可以指向于基类对象也可以指向于派生类对象

    1.8K10

    从零开始学C++之继承(二):继承与构造函数、派生类到基类的转换

    一、不能自动继承的成员函数 构造函数(包括拷贝构造函数) 析构函数 =运算符 二、继承与构造函数 基类的构造函数不被继承,派生类中需要声明自己的构造函数。...从输出可以看出: 派生类对象的构造次序: 先调用基类对象成员的构造函数,接着是基类的构造函数,然后是派生类的对象成员的构造函数,最后是派生类自身的构造函数。...四、派生类到基类的转换 当派生类以public方式继承基类时,编译器可自动执行的转换(向上转型 upcasting 安全转换) 派生类对象指针自动转化为基类对象指针 派生类对象引用自动转化为基类对象引用... *>(pm2);     //e1 = m2;  // 私有或保护继承的时候,派生类对象无法转化为基类对象。     ...; // 基类对象无法强制转化为派生类对象     return 0; } 五、基类到派生类的转换 基类对象指针(引用)可用强制类型转换为派生类对象指针(引用), 而基类对象无法执行这类转换.

    1.5K00

    c++类和继承面试点25连问

    ,先调用基类的构造函数,再调用派生类的构造函数; 派生类对象销毁时,先调用派生类的析构函数,再调用基类的析构函数。...运行时多态简单来讲就是:使用基类指针或者引用指向一个派生类对象,在非虚继承的情况下,派生类直接继承基类的虚表指针,然后使用派生类的虚函数去覆盖基类的虚函数,这样派生类对象通过虚表指针访问到的虚函数就是派生类的虚函数了...隐藏是指派生类的函数屏蔽了与其同名的基类函数,特征如下: 如果派生类的函数与基类的函数同名,但是参数不同,此时不论有没有virtual关键字,基类的函数都将被隐藏; 如果派生类的函数与基类的函数同名,参数也相同...析构函数是否可以为虚函数?如果可以,有什么作用? 析构函数可以是虚函数,因为它是对象结束时才调用,不影响虚表构建。...多重继承时类对象内存布局 非虚继承时,按照继承顺序存储,虚继承时,虚基类的内容放在一块内存的最后面存储。 详细的看之前这篇文章:c++头脑风暴-多态、虚继承、多重继承内存布局 21.

    99410

    C++:28 --- C++内存布局(上)

    成员函数基本上不影响类实例的大小。...正如下面访问I对象的c1成员那样,如果不是通过指针访问,而是直接通过对象实例,则派生类的布局可以在编译期间静态获得,偏移量也可以在编译时计算,因此也就不必要根据虚基类表的表项来间接计算了。...一般说来,当从派生类中访问虚基类成员时,应该先强制转化派生类指针为虚基类指针,然后一直使用虚基类指针来访问虚基类成员变量。这样做,可以避免每次都要计算虚基类地址的开销。 见下例。...与成员变量不同的是,通过在派生类中重新定义基类函数,一个派生类可以覆盖,或者说替换掉基类的函数定义。...“最终派生类”,调用虚基类的析构函数(按照相反顺序) 在VC++中,有虚基类的类的构造函数接受一个隐藏的“最终派生类标志”,标示虚基类是否需要初始化。

    1.1K20

    C++ 虚拟继承

    虚拟继承与普通继承不同的是,虚拟继承可以防止出现diamond继承时,一个派生类中同时出现了两个基类的子对象。也就是说,为了保证 这一点,在虚拟继承情况下,基类子对象的布局是不同于普通继承的。...4.2“覆盖”是指派生类函数覆盖基类函数,特征是: (1)不同的范围(分别位于派生类与基类); (2)函数名字相同; (3)参数相同; (4)基类函数必须有virtual 关键字。...4.3“隐藏”是指派生类的函数屏蔽了与其同名的基类函数,特征是: (1)如果派生类的函数与基类的函数同名,但是参数不同,此时,不论有无virtual关键字,基类的函数将被隐藏(注意别与重载混淆)。...(2)如果派生类的函数与基类的函数同名,但是参数相同,但是基类函数没有virtual 关键字。此时,基类的函数被隐藏(注意别与覆盖混淆)。...主要大小受三个因素的影响: 语言本身所造成的额外负担,当语言支持虚基类的时候,就导致一个额外的负担,这个一般都是一个虚表指针。里面存储的就是虚基类子对象的地址,就是偏移量。

    2.4K80

    C++面试知识总结

    C++程序的内存布局与C程序布局类似,区别是C++不再区分全局变量和静态变量是否已经初始化,全部存储在静态存储区;另外堆中存放new/delete申请释放的资源,而malloc和free申请的资源存放在自由存储区...函数覆盖是指派生类函数覆盖基类函数,函数名、参数类型、返回值类型一模一样。派生类的对象会调用子类中的覆盖版本,覆盖父类中的函数版本。 隐藏”是指派生类的函数屏蔽了与其同名的基类函数。...覆盖和隐藏的区别: 派生类的函数与基类的函数同名,但是参数不同。此时,不论有无virtual关键字,基类的函数将被隐藏。 派生类的函数与基类的函数同名,参数也相同。...3.5 基类和子类的构造、析构顺序 定义一个对象时先调用基类的构造函数、然后调用派生类的构造函数 先派生类的析构后基类的析构,也就是说在基类的的析构调用的时候,派生类的信息已经全部销毁了 3.6 深拷贝与浅拷贝的区别...,派生类的成员函数可以访问基类中的公有和受保护成员;公有继承时基类受保护的成员,可以通过派生类对象访问但不能修改。

    1.8K41

    c++头脑风暴-多态、虚继承、多重继承内存布局

    总结一下:c++继承时的多态一般指的运行时多态,使用基类指针或者引用指向一个派生类对象,在非虚继承的情况下,派生类直接继承基类的虚表指针,然后使用派生类的虚函数去覆盖基类的虚函数,这样派生类对象通过虚表指针访问到的虚函数就是派生类的虚函数了...,后面不再说明; 一个没有虚函数的类派生出一个没有虚函数的派生类,那么这个派生类的内存布局就是先基类成员变量,然后派生类成员变量组成的结构体,各成员变量在内存中存储顺序按照声明时的顺序来存放; 一个有虚函数的类...,在64位系统中就是占用8个字节; 一个派生类非虚继承于一个有虚函数的类,不论派生类是否有同样的虚函数,它的内存布局都只是在有虚函数的基类基础上增加派生类的成员变量,虚表指针是直接继承基类的,指向基类虚表指针...,如果派生类有同样的虚函数,那就覆盖基类虚表中同名函数,如果是派生类独有的虚函数,那就追加在基类虚函数表后面; 一个派生类虚继承于一个有虚函数且没有成员变量的基类,则派生类也不会生成它自己的虚表指针和虚函数表...,此时内存布局是首先是虚表指针,然后是派生类的成员变量,与第4点区别不大; 一个派生类虚继承于一个有虚函数且有成员变量的基类,此时派生类会重新生成它自己的虚表指针和虚函数表,内存布局则是派生类的虚表指针和成员变量在前

    71220

    C++多态

    类 D 同时继承 B 和 C,B 和 C 又继承自 A)体系下,虚表在各个类中的布局如何,如果类 B 和类 C 同时有一个成员变了 m,m 如何在 D 对象的内存地址上分布的,是否会相互覆盖 存在虚函数的类对象...如果对象类型是派生类,就调用派生类的函数;如果对象类型是基类,就调用基类的函数。运行期多态就是通过虚函数和虚函数表实现的。...如果派生类重写了基类的虚方法,该派生类虚函数表将保存重写的虚函数的地址,而不是基类的虚函数地址。...如果基类中的虚方法没有在派生类中重写,那么派生类将继承基类中的虚方法,而且派生类中虚函数表将保存基类中未被重写的虚函数的地址。...菱形继承(类 D 同时继承 B 和 C,B 和 C 又继承自 A)体系下,虚表在各个类中的布局如何,如果类 B 和类 C 同时有一个成员变了 m,m 如何在 D 对象的内存地址上分布的,是否会相互覆盖

    1.9K10

    解锁C++继承的奥秘:从基础到精妙实践(下)

    六、多继承的指针偏移问题 在C++的多继承中,指针偏移问题是指当使用基类指针指向派生类对象时,由于多继承导致内存布局复杂化,必须调整指针来正确访问派生类对象中的基类部分。...虚拟继承与普通继承的一个主要区别在于,虚拟继承需要通过虚基表(vtable) 或 指针调整 机制来处理基类的实例,而这些操作会影响对象的内存布局,并最终反映在编译后的汇编代码中。...下面将介绍虚拟继承与汇编之间的关系,特别是它如何影响内存布局、虚基表以及指针调整。 7.1 虚拟继承的内存布局 在普通继承中,派生类会直接包含基类的成员。...基类的成员是直接复制到派生类对象中,内存布局上派生类包含基类的所有数据成员。 而在虚拟继承中,基类的实例不再直接内嵌在派生类中,而是被共享。...7.1.1 内存布局对比 普通继承: 派生类直接内嵌基类,继承的所有基类数据成员按顺序排列。

    6510

    浅析C++类的内存布局

    : 单一继承的内存布局很清晰,每个派生类中起始位置都是Base class subobject。...所以上述的类设计其实有错误,带多态性质的基类应该声明一个virtual析构函数。如果class带有任何virtual函数,它就应该拥有一个virtual析构函数。...而类C的内存布局如下: 可见,派生类C中依其继承的基类的顺序,存放了各个基类subobject及各自的vptr,然后才是Class C自己的数据成员。...同时也可以想到,随着base class的数量增多,派生类里也会首先顺序存放各个基类subobject。而派生类中也会记录其到各个base subobject的offset。...类B和C的内存布局如2.2。接下来看类D的内存布局: 如上图,D中依次存放基类B subobject和基类C subobject。其中B和C中均存放一份class A subobject。

    56610

    《C++Primer》第十五章 面向对象程序设计

    ),如果基类希望它的派生类有权访问某成员同时禁止其他用户访问,那么应该用protected关键字。...公有、私有和受保护继承 某个类对继承而来的成员呢的访问权限收到两个因素影响:一个是基类中该成员的访问说明符,第二个是在派生类的派生列表中的访问说明符。...; } } 派生访问说明符对于派生类的成员(及其友元)能否访问其直接基类的成员没什么影响。...和其他类一样,基类应该将其接口成员声明为公有的;同时将属于其实现的部分分成两组:一组可供派生类访问,另一组只能由基类及基类的友元访问。...虚析构函数 继承关系对基类拷贝控制最直接的影响是基类通常应该定义一个虚析构函数,这样我们就可以动态分配继承体系中的对象了。

    1.2K20

    60条面向对象设计原则

    (8)类应该只表示一个关键抽象。   包中的所有类对于同一类性质的变化应该是共同封闭的。一个变化若对一个包影响,则将对包中的所有类产生影响,而对其他的包不造成任何影响 ....(37)派生类必须知道基类,基类不应该知道关于它们的派生类的任何信息。   (38)基类中的所有数据都应当是私有的,不要使用保护数据。   ...(52)在派生类中用空方法(也就是什么也不做的方法)来覆写基类中的方法应当是非法的。   (53)不要把可选包含同对继承的需要相混淆。把可选包含建模成继承会带来泛滥成灾的类。   ...(56)只要在面向对象设计中用到了继承,问自己两个问题:(1)派生类是否是它继承的那个东西的一个特殊类型?(2)基类是不是派生类的一部分?   ...(57)如果你在一个面向对象设计中发现了多重继承关系,确保没有哪个基类实际上是另一个基类的派生类。   (58)在面向对象设计中如果你需要在包含关系和关联关系间作出选择,请选择包含关系。

    82760

    后台开发:核心技术与应用实践 -- C++

    同时,无论哪一种继承方式,在派生类中是不能访问基类的私有 成员的,私有成员只能被本类的成员函数所访问,毕竟派生类与基类不是同一个类 构造派生类的对象时,必须对基类数据成员、新增数据成员和成员对象的数据成员进行初始化...派生类构造函数必须对这3类成员进行初始化,其执行顺序是这样的: 先调用基类构造函数; 再调用子对象的构造函数; 最后调用派生类的构造函数体 当派生类有多个基类时,处于同一层次的各个基类的构造函数的调用顺序取决于定义派生类时声明的顺序...在派生时,派生类是不能继承基类的析构函数的,也需要通过派生类的析构函数去调用基类的析构函数。...在派生类中可以根据需要定义自己的析构函数,用来对派生类中所增加的成员进行清理工作;基类的清理工作仍然由基类的析构函数负责。...而 虚函数 的作用是允许在派生类中重新定义与基类同名的函数,并且可以通过基类指针或引用来访问基类和派生类中的同名函数。

    1.3K10

    图说C++对象模型:对象内存布局详解

    简单对象模型的缺点就是因间接性导致的空间存取时间上的额外负担,优点则是类的大小是固定的,基类的改动不会影响子类对象的大小。...5.2.2 菱形继承 菱形继承也称为钻石型继承或重复继承,它指的是基类被某个派生类简单重复继承了多次。这样,派生类对象中拥有多份基类实例(这会带来一些问题)。...根据我们前面对虚继承的派生类的内存布局的分析,B1类的对象模型应该是这样的: ?...现在,我们对虚基类表的构成应该有了一个更好的理解。...b1虚继承于b,编译器为其安插一个4字节的虚基类表指针(32为机器),此时b1已不为空,编译器不再为其安插1字节的char(优化)。 b2同理。 d含有来自b1与b2两个父类的两个虚基类表指针。

    4.2K43

    61条面向对象设计的经验原则

    p18   (8)类应该只表示一个关键抽象。p19   包中的所有类对于同一类性质的变化应该是共同封闭的。一个变化若对一个包影响,则将对包中的所有类产生影响,而对其他的包不造成任何影响 ....p74   (37)派生类必须知道基类,基类不应该知道关于它们的派生类的任何信息。p74   (38)基类中的所有数据都应当是私有的,不要使用保护数据。...现在,把这些对象概括成一个类。 p103   (52)在派生类中用空方法(也就是什么也不做的方法)来覆写基类中的方法应当是非法的。p103   (53)不要把可选包含同对继承的需要相混淆。...p120   (56)只要在面向对象设计中用到了继承,问自己两个问题:(1)派生类是否是它继承的那个东西的一个特殊类型?(2)基类是不是派生类的一部分?...p121   (57)如果你在一个面向对象设计中发现了多重继承关系,确保没有哪个基类实际上是另一个基类的派生类。

    57720
    领券