$proxy_add_x_forwarded_for; } # 指定请求状态码 跳转指定页面 error_page 500 502 503 504 404 /404.html ; # 定义自己的404页面 location = /404.html { root /home/java/nginx_html; } # $ { # 跳转自己的错误页面特面 root /home/java/nginx_html/; } # 错误日志一定要去查看是否有效哈,最好提前准备好文件夹
浏览量 1 1.类里如果声明了虚函数,这个函数是实现的,哪怕是空实现,它的作用就是为了能让这个函数在它的子类里面可以被覆盖(override),这样的话,编译器就可以使用后期绑定来达到多态了。 纯虚函数只是一个接口,是个函数的声明而已,它要留到子类里去实现。 2.虚函数在子类里面可以不重写;但纯虚函数必须在子类实现才可以实例化子类。 3.虚函数的类用于 “实作继承”,继承接口的同时也继承了父类的实现。纯虚函数关注的是接口的统一性,实现由子类完成。 4.带纯虚函数的类叫抽象类,这种类不能直接生成对象,而只有被继承,并重写其虚函数后,才能使用。抽象类被继承后,子类可以继续是抽象类,也可以是普通类。 5.虚基类是虚继承中的基类,具体见下文虚继承。
2核2G云服务器 每月9.33元起,个人开发者专属3年机 低至2.3折
虚函数与虚继承寻踪 封装、继承、多态是面向对象语言的三大特性,熟悉C++的人对此应该不会有太多异议。 前四个字节存储的是虚函数表的指针vfptr,后四个字节存储对象成员var的值。虚函数表的大小为4字节,就一条函数地址,即虚函数fun的地址,它在虚函数表vftable的偏移是0。 图4 MyClassC对象模型 虚基类表每项记录了被继承的虚基类子对象相对于虚基类表指针的偏移量。 和虚函数表不同的是,虚基类表的第一项记录着当前子对象相对与虚基类表指针的偏移。MyClassA和MyClassB子对象内的虚表指针都是存储在相对于自身的4字节偏移处,因此该值是-4。 通过以上的对象组织形式,编译器解决了公共虚基类的多份拷贝的问题。通过每个父类的虚基类表指针,都能找到被公共使用的虚基类的子对象的位置,并依次访问虚基类子对象的数据。
实线边框渐变 .border-block { border: 10px solid transparent; border-image: linear-gradient(to top, blue #000 6px, transparent 6px) repeat-y 100% 0; mask-size: 8px 2px, 2px 8px, 8px 2px, 2px 8px; } } HTML
,在基类的类定义中定义虚函数的一般形式: virtual 函数返回值类型 虚函数名(形参表) { 函数体 } 虚函数的作用是实现动态联编,也就是在程序的运行阶段动态地选择合适的成员函数,在定义了虚函数后 定义虚函数的限制: (1)非类的成员函数不能定义为虚函数,类的成员函数中静态成员函数和构造函数也不能定义为虚函数,但可以将析构函数定义为虚函数。 为什么虚函数必须是类的成员函数: 虚函数诞生的目的就是为了实现多态,在类外定义虚函数毫无实际用处。 我们可以看到下面几点: 1)虚函数按照其声明顺序放于表中。 2)父类的虚函数在子类的虚函数前面。 一般继承(有虚函数覆盖) 覆盖父类的虚函数是很显然的事情,不然,虚函数就变得毫无意义。 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/154453.html原文链接:https://javaforall.cn
虚函数(impure virtual) C++的虚函数主要作用是“运行时多态”,父类中提供虚函数的实现,为子类提供默认的函数实现。 子类可以重写父类的虚函数实现子类的特殊化。 ; 纯虚函数(pure virtual) C++中包含纯虚函数的类,被称为是“抽象类”。 C++中的纯虚函数也是一种“运行时多态”。 virtual void xhs(){ //这个虚函数必须得在基类中实现 cout<<"我是基类的虚函数"<<endl;//即使是空的虚函数也要在基类中实现 } //派生类中可以不写这个函数,但是派生类对象调用时会调用积累的虚函数 //纯虚函数 virtual void cxhs() =0; //这个纯虚函数不在基类中实现,必须在子类中实现
虚函数 代码如下定义: // test1107.cpp : 定义控制台应用程序的入口点。 son s; cout<<f.get_age()<<endl; cout<<s.get_age()<<endl; system("pause"); } 输出为: 1 0 在基类中的虚函数 当基类中的虚函数定义时,是使用指针或者引用作为参数,那么在运行是,要判断传入的参数,是基类的对象,还是派生类的对象。 如果是基类的对象,则调用基类中的虚函数定义。 如果是派生类的对象,则调用派生类中对基类虚函数的新定义的函数。
虚析构和纯虚析构 多态使用时,如果子类有属性开辟到堆区,那么父类指针在释放时无法带调用到子类的析构代码 解决方式:将父类的析构函数改为纯虚析构或者虚析构 虚析构和纯虚析构的共性: 1.可以解决父类指针释放子类对象 2.都必须要有具体的函数实现 虚析构和纯虚析构的区别: 如果是纯虚析构,该类属于抽象类,无法实例化对象 #include<iostream> #include<string> using namespace std; class animal { public: //构造函数 animal() { cout << "animal的构造函数调用" << endl; } //纯虚函数 virtual void speak() { cout << "动物在说话" << endl; } //虚析构 virtual ~animal() { cout << "animal的析构函数调用"
借助 VMware Data Recovery (VDR)、vSphere Data Protection (VDP) 或利用更改块跟踪 (CBT) 来执行增量...
lineStyle:{ width:2, type:'dotted' //'dotted'虚线 'solid'实线 DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> <script width: 2, type: 'dotted' //'dotted'虚线 'solid'实线 y_data }] }, true); } </script> </body> </html
此种菱形继承多存储了两倍的A的内存段,下面将介绍虚基类 ? 二、虚基类(virtual) 1.概念:也称虚继承、菱形继承。 用于多级混合继承时,保留一个虚基类 2.构造顺序 先构造虚基类,如果有多个虚基类,按声明(从左至右)依次构造 再构造基类,如果有多个基类,按声明(从左至右)依次构造 如果有子对象,再构造子对像,如果有多个子对象 再接着构造C,发现C继承于虚基类A,但发现虚基类A已经被B构造过了,所以不再构造A,直接构造C。 ,其大小为4字节 2.注意 只有类中有虚函数时,才有虚函数表 父子类之间的虚函数表是不同的地址,且虚函数表中的虚函数的首地址也不同 class A { public: virtual void run1 原理:通过指针遍历虚函数表然后打印虚函数,虚函数都是按照顺序在内存中存储的 class A { public: virtual void run1(){cout<<"A1";}; virtual void
文章目录 引言: 一、虚函数的定义和使用 关于虚函数,说明以下几点: 虚函数的访问 二、纯虚函数 三、补充内容 指向类中数据成员的指针变量 例题: 引言: 若要访问派生类中相同名字的函数,必须将基类中的同名函数定义为 关于虚函数,说明以下几点: 1、当在基类中把成员函数定义为虚函数后,在其派生类中定义的虚函数必须与基类中的虚函数同名,参数的类型、顺序、参数的个数必须一一对应,函数的返回的类型也相同。 5、可把析构函数定义为虚函数,但是,不能将构造函数定义为虚函数。 6、虚函数与一般的成员函数相比较,调用时的执行速度要慢一些。 二、纯虚函数 基类中不对虚函数给出有意义的实现,它只是在派生类中有具体的意义。这时基类中的虚函数只是一个入口,具体的目的地由不同的派生类中的对象决定。这个虚函数称为纯虚函数。 p = &b; p->SS(9.9, 2.0); return 0; } 结果如下: 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/171000.html
(有虚函数覆盖) 4、多重继承情况(无虚函数覆盖) 5、多重继承情况(有虚函数覆盖) 四、虚函数的相关问题 1、构造函数为什么不能定义为虚函数 2、析构函数为什么要定义为虚函数? 只要有虚函数,C++类都会存在这样的一张虚函数表,不管是普通虚函数亦或是纯虚函数,亦或是派生类中隐式声明的这些虚函数都会生成这张虚函数表。 虚函数表创建的时间:在一个类构造的时候,创建这张虚函数表,而这个虚函数表是供整个类所共有的。虚函数表存储在对象最开始的位置。虚函数表其实就是函数指针的地址。 3、单继承情况(有虚函数覆盖) 覆盖父类的虚函数是很显然的事情,不然,虚函数就变得毫无意义。下面,我们来看一下,如果子类中有虚函数重载了父类的虚函数,会是一个什么样子? e8ce861fdfb90f09aaa9a5f3c3bbf38b342f73fdfbe37c111c39937e7baa931fc0ac73cf8074#rd 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/158739.html
纯虚函数和抽象类 概念 首先引入“纯虚函数”和“抽象类”的概念,示例代码如下 #include<iostream> using namespace std; class Base //抽象类 { public ”与“纯虚析构”。 虚析构与纯虚析构 虚析构 虚析构的实现与虚函数一致,只需要在父类的析构函数前面加上virtual关键字即可,只需要将前面代码中的Animal基类改成: class Animal { public: :~Animal() { cout << "Animal纯虚析构函数调用" << endl; } 值得注意的是,纯虚析构必须在类外具体实现,否则将无法完成编译。 拥有纯虚析构的类也叫做抽象类,无法实例化对象。
我们一步步看一下: 【步骤1:交请假单】 问题所给图中,人事系统没有实线或虚线箭头指向主管,也就是说,人事系统在这一步没有和主管有任何交互。 如果是下面这样,人事系统和主管有一条实线: 图2 意思是,员工使用人事系统交请假单,人事系统请求主管批假,而且员工是期望着马上批的。
简介 虚树,顾名思义就是不真实的树。 它往往出现在一类树形动态规划问题中。 换句话说,虚树实际就是为了解决一类树形动态规划问题而诞生的! 于是,虚树诞生了 虚树 思想 虚树的主要思想是:对于一棵树,仅仅保留有用的点,重新构建一棵树 这里有用的点指的是询问点和它们的lca 煮个栗子 比如这样的一棵树(没错就是样例) ? 对于样例中的三次询问, 3 2 10 6 4 5 7 8 3 3 9 4 6 那么它的虚树分别长这样 ? ? ? 此处较为抽象,建议大家画图理解一下 不断重复这个过程,虚树就构建完成了,另外我们需要维护出链上的最小值,然后我们直接在虚树上dp就可以了 复杂度 虚树上除了要加入的询问点外,还有可能出现的$LCA$ 那么虚树中的点数是$O(2*k)$的。 这样复杂度就只与k有关,$O(2*\sum k_i)$。
对于经常被问到的虚函数和多态的问题,发现百度百科回答得十分详细,所以自己在百度百科上的解释进行总结 一、虚函数 (1)虚函数简介:在某基类中声明为virtual并在一个或者多个派生类中被重新定义的成员函数 作为基类的Animal的成员函数speak( )被定义为虚函数,相应的其派生类Dog的成员函数speak( )自动变为虚函数;所以对于派生类中相应成员函数是否加上virtual关键字修饰,是可选的,但是为了可读性 (5)限制条件: 非类的成员函数不能定义为虚函数,类的成员函数中静态函数、构造函数也不能定义为虚函数,但是析构函数可以被定义为虚函数; 当基类中的某一成员函数声明为虚函数后,派生类中的同名函数(函数名相同 (6)总结: 指向基类的指针在操作它的多态对象时,会根据不同的类对象,调用其相应的函数,这个函数就是虚函数; 虚函数联系到多态,多态联系到继承。 二、多态性 多态是指同一个实体同时具有多种形式。 举个例子:从一个基类中派生,响应一个虚命令,产生不同的结果。
定义 纯虚函数就是在基类中声明的虚函数,它在基类中没有定义,但要求任何派生类都要定义自己的实现方法。 纯虚函数的意义在于,让所有的类对象(主要是派生类对象)都可以执行纯虚函数的动作,但类无法为纯虚函数提供一个合理的缺省实现。 使用抽象类时注意: 抽象类只能作为基类来使用,其纯虚函数的实现由派生类给出。如果派生类中没有重新定义纯虚函数,而只是继承基类的纯虚函数,则这个派生类仍然是一个抽象类。 纯虚函数和虚函数有什么区别 纯虚函数声明如下:virtual void function1()=0; 纯虚函数一定没有定义,纯虚函数用来规范派生类的行为, 即接口。 实现了纯虚函数的子类,该纯虚函数在子类中就变成了了虚函数,子类的子类可以覆盖该虚函数,由多态方式调用的时候动态绑定。 虚函数是C++中用于实现多态的机制。核心理念就是通过基类访问派生类定义的函数。
C++实现虚函数的方法:为每个类对象添加一个隐藏成员,隐藏成员保存了一个指针,这个指针叫虚表指针(vptr),它指向一个虚函数表(virtual function table, vtbl)(备注:一个类对象一个虚指针 虚函数表就像一个数组,表中有许多的槽(slot),每个槽中存放的是一个虚函数的地址(可以理解为数组里存放着指向每个虚函数的指针)。如下所示: ? 说明: 1.虚函数列表中的最后一个.表示的是虚函数列表的结束符,类似于字符串的/0。 2.虚函数指针往往是在类对象的第一个元素。 3.对于派生类而言,如果派生类实现了基类中的虚函数,在派生类的虚函数列表中,对应的虚函数会被替换成派生类的这个函数地址。 基类的虚函数列表和继承类的虚函数列表是两个,是不相同的,继承类的虚函数列表中存储的是继承类的虚函数实现,如果继承类没有实现基类的虚函数的话,会存储基类的虚函数地址。例子参见继承类的执行结果。
腾讯云慧眼人脸核身(原金融级身份认证升级版)是一组对用户身份信息真实性进行验证审核的服务套件,提供各类认证功能模块,包含证件OCR识别、活体检测、人脸1:1对比、及各类要素信息核验能力,以解决行业内大量对用户身份信息核实的需求,广泛应用于金融、保险、政务民生、互联网、交通出行等领域。
扫码关注腾讯云开发者
领取腾讯云代金券