参考链接: C++继承 继承 类和类的关系有组合、继承和代理。继承的本质就是代码复用。子类继承父类中的一些东西,父类也称为基类,子类也称为派生类。派生类继承了基类除构造函数以外的所有成员。 ...基类中不同访问限定符下(public、protected、private)的成员以不同的继承方式继承,在派生类中的访问限定也不同,具体如下: 基类的布局优先于派生类 #include基类的构造函数 2.调用派生类的构造函数 派生类的析构可想而知: 1.调用派生类的析构函数 2.调用基类的析构函数 虚函数 如下程序: class Base { public: Base...基类中含有虚函数,那么基类布局中存在一个虚函数指针,指向虚函数表;且其派生类中与其同名同参的函数不需要加virtual也是虚函数。...此时基类和派生类的布局如下: vfptr的指针大小为4(32位机器)。因此基类字节数为8,派生类为12。
C++中派生类对基类成员的访问形式主要有以下两种: 1、内部访问:由派生类中新增成员对基类继承来的成员的访问。 2、对象访问:在派生类外部,通过派生类的对象对从基类继承来的成员的访问。...1、私有继承的访问规则 当类的继承方式为私有继承时,基类的public成员和protected成员被继承后成为派生类的private成员,派生类的其它成员可以直接访问它们,但是在类的外部通过派生类的对象无法访问...基类的private成员在私有派生类中是不可直接访问的,所以无论是派生类的成员还是通过派生类的对象,都无法直接访问从基类继承来的private成员,但是可以通过基类提供的public成员函数间接访问。...基类的private成员在私有派生类中是不可直接访问的,所以无论是派生类成员还是派生类的对象,都无法直接访问从基类继承来的private成员,但是可以通过基类提供的public成员函数直接访问它们。...基类的private成员在私有派生类中是不可直接访问的,所以无论是派生类成员还是通过派生类的对象,都无法直接访问基类中的private成员。
二、转换的本质 派生类可以转换为基类的本质是: ①为什么派生类可以转换为基类:派生类从基类而来,因此派生类中包含了基类的方法和成员。...此时基类可以通过指针或引用指向派生类(相当于将派生类从基类中继承的那部分方法和成员绑定到基类上了,相当于派生类被截断了),然后基类就可以将派生类假装是一个基类对象来使用(调用其中的成员/方法) ②为什么基类不能转换为派生类...如果将一个基类对象绑定到派生类的指针/引用上,此时派生类通过指针/引用访问自己新定义的成员/方法时,发现找不到(因此不能将基类转换为派生类) 例如:下面B继承于A,子类继承于父类,同时为父类的成员开辟了空间...//假设B公有继承于A A *a; B b; a = &b; //将派生类转换为基类,正确 B *p = a; //将基类再转换为派生类,错误 五、类静态类型/类动态类型 在上面我们介绍过,基类的指针或引用可以指向于基类对象也可以指向于派生类对象...演示案例② 我们修改演示案例①,上面是将基类的指针指向于派生类。
这里的不可见是指基类的私有成员还是被继承到了派生类对象中,但是语法上限制派生类对象不管在类里面还是类外面都不能去访问它 我们前面知道,类里面可以访问它的成员,但是private继承下,子类是无法访问父类的成员的...无法访问,因为_No是Student特有的成员,即使它实际上存在于sobj中 即使我们通过基类引用或指针操作对象,派生类对象的完整信息(所有成员变量和函数)仍然都在内存中,没有丢失。...在使用引用或指针时,这种情况并不会发生 基类对象不能赋值给派生类对象 基类的指针或者引用可以通过强制类型转换赋值给派生类的指针或者引用。但是必须是基类的指针是指向派生类对象时才是安全的。...子类和父类中有同名成员,子类成员将屏蔽父类对同名成员的直接访问,这种情况叫隐藏,也叫重定义。...C++ 规则规定,如果派生类提供了和基类同名的函数,基类中同名的函数在派生类的作用域就不再可见了 因此,在 B 类的成员函数 fun(int) 中,调用 fun() 试图无参数调用被隐藏的同名函数会无法编译
当创建一个类时,程序员不需要完全重新编写新的数据成员和成员函数,只需要设计一个新的类,继承了已有的类的成员即可。这个已有的类被称为的基类,这个新的类被称为派生类。...基类和派生类 一个类可以派生自多个类或接口,这意味着它可以从多个基类或接口继承数据和函数。...C# 中创建派生类的语法如下: class 基类> { ... } class 派生类> : 基类> { ... } 假如一个基类是Shape,一个派生类是Rectangle...Console.WriteLine(rect.getArea()); Console.ReadLine(); } } } 结果: 30 基类的初始化...派生类继承了基类的成员变量和成员方法。
“强制实现”,也就是只要是父类指针调用普通函数,那就是父类的普通函数 而虚函数的作用,主要是为了让父类指针可以调用子类的函数,这种是在运行时才决定调用哪个函数 1、虚函数: C++的虚函数主要作用是...子类可以重写父类的虚函数实现子类的特殊化。 2、纯虚函数: C++中包含纯虚函数的类,被称为是“抽象类”。抽象类不能使用new出对象,只有实现了这个纯虚函数的子类才能new出对象。 ...C++中的纯虚函数更像是“只提供申明,没有实现”,是对子类的约束,是“接口继承”。 C++中的纯虚函数也是一种“运行时多态”。...3、普通函数: 普通函数是静态编译的,没有运行时多态,只会根据指针或引用的“字面值”类对象,调用自己的普通函数。 普通函数是父类为子类提供的“强制实现”。 ...因此,在继承关系中,子类不应该重写父类的普通函数,因为函数的调用至于类对象的字面值有关。 参考链接
派生类对象自动转换为基类对象(特有的成员消失) 当派生类以private/protected方式继承基类时 派生类对象指针(引用)转化为基类对象指针(引用)需用强制类型转化。...但不能用static_cast,要用reinterpret_cast 不能把派生类对象强制转换为基类对象 #include #include using namespace...无法将基类对象看成是派生类对象 e1 = m1; // 派生类对象可以转化为基类对象。将派生类对象看成基类对象 // 会产生对象切割(派生类特有成员消失)。...//e1 = reinterpret_cast(m2); // 私有或保护继承的时候,派生类对象无法强制转化为基类对象。 ...; // 基类对象无法强制转化为派生类对象 return 0; } 五、基类到派生类的转换 基类对象指针(引用)可用强制类型转换为派生类对象指针(引用), 而基类对象无法执行这类转换.
.152: Never assign a pointer to an array of derived class objects to a pointer to its base C.152:永远不要将派生类数组的指针赋值给基类指针...作为赋值结果的基类指针的下标运算会引起无效的对象访问并可能发生内存破坏。...提示所有数组退化和基类类型向派生类类型转换的情况。...suffer a derived-to-base conversion before getting into the span 使用span传递数组而不是指针,也不要再放入span之前让数组名经过一次派生类向基类类型的转换
C.137: Use virtual bases to avoid overly general base classes C.137: 使用虚基类避免过于一般的基类 Reason(原因)...允许共享数据和接口的分离。避免将所有的共享数据放进一个终极基类中。...如果很多派生类之间分享特别有用的共通的"实现细节",从中分离出共通功能就是有意义的。...很显然,示例过于理论化了,但是找到一个接近现实的小例子太难了。接口是接口体系的起点,而公用程序是实现体系的起点。这里有一个带有说明的,略微更接近实际的例子。...提示接口继承和实现继承体系混合的情况。
T.62: Place non-dependent class template members in a non-templated base class T.62:将非依赖类模板成员放入非模板基类中...允许在不定义模板参数和不例示模板的情况下使用基类成员。...本规则的更普遍版是:如果模板类成员只依赖于M以外的N个模板参数,将其放入只包含N个参数的基类中。对于N==1的情况,我们可以选择外围作用域的某个类的基类,就像T.61那样。 常量该如何处理?
C++有一个很方便的功能—隐式转换,比如有一个函数 void func(double f); 调用它的时候 func(5); func(5.0); 都是有效的。 但有时候,这个功能就很麻烦了。...,因为std::string可以隐式转换为类A对象。...C++ 标准有一条规定: “Implicit conversions will be performed […] if the parameter type contains no template-parameters...函数 c++选择函数时优先考虑满足条件的非模板函数,然后才是符合条件的模板函数。...如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
我们都知道C++完全兼容C语言,C语言的转换方式很简单,可以在任意类型之间转换,但这也恰恰是缺点,因为极其不安全,可能不经意间将指向const对象的指针转换成非const对象的指针,可能将基类对象指针转成了派生类对象的指针...static_cast是用得最多的一类类型转换符,常见的枚举值转成整形,float转整形之类的,都是可以的。...另外,static_cast还可以将派生类指针转换为基类指针,而且一定条件下还能将基类指针转换为派生类指针,且不会报错,只是一些只有派生类才会有的函数、成员变量,转换过来的指针也不会有。...dynamic_cast,一般只用于基类和派生类之间的转换,而且只能用于派生类指针转换成基类指针,不能反向转换。...目前c++中有3个支持RTTI的元素:dynamic_cast,将一个指向基类的指针来生成一个指向派生类的指针,否则,该运算符将返回空指针typeid,返回一个指针对象类型的值type_info,结构存储了有关特定类型的信息
它主要有如下几种用法: ①用于类层次结构中基类(父类)和派生类(子类)之间指针或引用的转换。...进行上行转换(把派生类的指针或引用转换成基类表示)是安全的; 进行下行转换(把基类指针或引用转换成派生类表示)时,由于没有动态类型检查,所以是不安全的。...2、C++中的reinterpret_cast主要是将数据从一种类型的转换为另一种类型。所谓“通常为操作数的位模式提供较低层的重新解释”也就是说将数据以二进制存在形式的重新解释。...C++同时提供了4种新的强制类型转换形式(通常称为新风格的或C++风格的强制转 型):const_cast(expression)、dynamic_cast(expression)、 reinterpret_cast...例如,试图使用一个const_cast以外的新风格 强制转型来消除常量性,代码将无法编译。
C++的类型转换 零、前言 一、C语言的类型转换 二、C++强制类型转换 1、static_cast 2、reinterpret_cast 3、const_cast 4、dynamic_cast 5、...,就需要发生类型转化 C语言中的两种形式的类型转换: 隐式类型转化:编译器在编译阶段自动进行,能转就转,不能转就编译失败 显式类型转化:需要用户自己处理 示例: void Test () {...显式类型转换将所有情况混合在一起,代码不够清晰 因此C++提出了自己的类型转化风格,注意因为C++要兼容C语言,所以C++中还可以使用C语言的转化风格 二、C++强制类型转换 标准C...static_cast,命名上理解是静态类型转换 使用场景: 用于类层次结构中基类和派生类之间指针或引用的转换 注意: 上行转换(派生类—->基类)是安全的;下行转换(基类—->派生类)由于没有动态类型检查...使用场景: 不到万不得已,不用使用这个转换符,高危操作 使用特点: reinterpret_cast可以将整型转换为指针,也可以把指针转换为数组 reinterpret_cast可以在指针和引用里进行肆无忌惮的转换
一、抛出 / 捕获 多个类型异常对象 1、标准异常类 在 C++ 语言中 , 提供了一系列的 " 标准异常类 " , 这些 " 标准异常类 " 都继承了 std::exception 基类 , 在 标准库...中 , 抛出的异常 , 都是 标准异常类 , 都是 std::exception 类的子类 ; 2、标准异常类继承结构 标准异常类 定义在 std 命名空间 , 标准异常类 基类 std::exception..._What : "Unknown exception"; } } 标准异常类的继承关系如下图所示 : 上图中 runtime_error 和 logic_error 两个重要的异常类型基类... 3、常用的标准异常类 常用的标准异常类如下 : std::exception 是标准异常类 基类 , 定义了 what() 函数 , 该方法返回一个指向 C 字符串的指针 ,...::exception 基类 代码示例 : #include #include using namespace std; // 自定义类实现标准异常类基类
) static_cast可以用于有继承关系类对象之间的转换和类指针之间的转换 (派生类转换成基类时安全(上行转换),基类转换成派生类时不安全(下行转换)) 3.2 reinterpret_cast...3.4 dynamic_cast 动态转换 dynamic_cast用于将一个父类对象的指针/引用转换为子类对象的指针或引用(动态转换) 向上转换:子类对象指针/引用->父类指针/引用(不需要转换,赋值兼容规则...) 向下转换:父类对象指针/引用->子类指针/引用(用dynamic_cast转型是安全的) 学习过继承之后,我们知道派生类内部是包含一个基类,可以通过切片的方式来转换成基类!...这是天然支持的!但是对于基类转换为子类就有点复杂了!...void func(A* pa) { B* pb = (B*)pa; } 对于这样一个函数,基类指针会强制类型转换为子类指针,当pa指针本来就是指向的是一个B对象,在转换回去,没有问题。
C.87: Beware of == on base classes C.87:小心基类的相等运算符 Reason(原因) It is really hard to write a foolproof...为继承体系写出简单又好用的相等运算符真的很难。...B的相等比较运算符的第二个操作数接受类型转换,但是第一个不行。...ways of making == work in a hierarchy, but the naive approaches do not scale 当然有办法让相等比较运算符在继承体系中动作,但是简单的方法不行...提示被定义为虚函数的相等比较运算符;其他比较运算符也一样:!=, , 和 >=。
3.2 static_cast static_cast相当于传统的C语言中那些“较为合理”的强制类型转换,较多的使用于基本数据类型之间的转换、基类对象指针(或引用)和派生类对象指针(或引用)之间的转换、...(4)在C++中,只想派生类对象的指针可以隐式转换为指向基类对象的指针。...基类指针(引用)转换为派生类指针(引用)为向下转换,被编译器视为安全的类型转换,也可以使用static_cast进行转换。...(2)在多重继承的情况下,派生类的多个基类之间进行转换(称为交叉转换:crosscast)。如父类A1指针实际上指向的是子类,则可以将A1转换为子类的另一个父类A2指针。...而且从程序的意图来看,这里的转换是“合理”的。不过,C++是一种强制类型安全的语言,即使是用interpret_cast,也不能任意地将某种类型转换为另一种类型。
3.2 static_cast static_cast相当于传统的C语言中那些“较为合理”的强制类型转换,较多地用于基本数据类型之间的转换、基类对象指针(或引用)和派生类对象指针(或引用)之间的转换、一般的指针和...(4)在C++中,只想派生类对象的指针可以隐式转换为指向基类对象的指针。...基类指针(引用)转换为派生类指针(引用)为向下转换,被编译器视为安全的类型转换,也可以使用static_cast进行转换。...(2)在多重继承的情况下,派生类的多个基类之间进行转换(称为交叉转换:crosscast)。如父类A1指针实际上指向的是子类,则可以将A1转换为子类的另一个父类A2指针。...不过,C++是一种强制类型安全的语言,即使使用interpret_cast,也不能任意地将某种类型转换为另一种类型,C++编译器会设法保证“最低限度”的合理性。
C++中的类型转换操作一、C++转型操作符的种类及用途1.1 static_cast主要用途:进行隐式类型转换,如将 int 转换为 float,或指针转换为 void*。...调用显式或隐式的转换函数,可增加代码可读性。在继承体系中进行类型转换:向上转换(派生类到基类)通常是安全的隐式转换,无需使用 static_cast。...向下转换(基类到派生类)需使用 static_cast,但不能通过虚拟继承转换,且不进行运行时检查,若目标类型并非对象实际类型会导致未定义行为。...示例:static_cast(1); // 将整数 1 显式转换为浮点数 1.01.2 const_cast主要用途:专门用于添加或移除变量的 const 属性,这是其他 C++ 类型转换操作符无法做到的...b 转换为派生类指针 d,由于 b 指向 Derived 类对象,转换成功,避免了非法访问。
领取专属 10元无门槛券
手把手带您无忧上云