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

构造函数调用子类方法,写过吗?

为什么Base构造函数与虚构函数即使调用虚函数,也是调自己函数呢?这跟构造函数与虚构函数调用顺序有关。子类对象构造时候,先调父类构造函数初始化父类,再调子类构造函数初始化子类。...子类对象虚构时候,恰恰相反,先调子类对象虚构函数,再调父类虚构函数。输出结果也证明了这点。 所以如果父类构造函数与虚构函数是调用子类函数,那就非常危险了。...因为父类构造函数执行时,子类构造函数还没有执行,说明子类还没有初始化,而这时就调用子类方法,很容易出错,甚至崩溃。...父类虚构函数执行时候,子类虚构函数已经执行完毕,说明子类资源已经被释放,而这时继续执行子类方法,也很容易崩溃。于是,C++规范为此作了此约束。...如果真的很想在构造函数内调用子类方法进行初始化,还是显示提供一个初始化函数,让子类对象实例化完后,显示调用初始化函数

1.4K20
您找到你想要的搜索结果了吗?
是的
没有找到

Java中子类和父类构造函数

参考链接: Java中继承和构造函数 这篇文章总结了关于Java构造常见​​问题。  1)为什么创建一个子类对象要也需要调用父类构造函数? ...这是上边Super类发生情况。  子类构造函数,无论有参构造还是无参构造,将会调用父类中默认无参构造函数。...由于编译器试图插入super()这条语句到子类两个构造函数中,但Super默认构造函数没有被定义,所以编译器会报该错误消息。 ...3)子类显式调用父类构造函数  下面的代码是正常:    子类(Sub)构造函数显式地调用父类(Super)中带参构造参数。如果父类中定义了相对应构造函数,那将会被正常良好调用。  ...4)规则 简而言之,规则是:子类构造函数必须调用父类中构造函数,无论隐式调用还是显式调用,无论哪种方式,被调用构造函数必须得先被定义。

2K20

小朋友学C++(10):子类构造函数调用父类构造函数

从哲学层面来看,子类会继承父类除private以外所有成员。 因为构造函数是公有的,所以理所当然地会被子类继承。...分析: 这里构造函数写法是 Rectangle() : Shape() { 子类构造函数本身语句; } 这是先调用父类构造函数,再执行它本身语句。从运行结果也可以看出这一点。...那么,如果不显示调用父类构造函数Shape()呢?父类构造函数就不被调用了吗? 咱们可以用下面的程序来验证。...分析: 从运行结果可以看出,程序1和程序2运行结果完全一致。也就是说,Shape()即使不显示调用,实际上也会被调用。并且调用顺序优先于子类本身构造函数

1.3K60

【Kotlin】Kotlin 类继承 一 ( 类继承基本方式 | final 关键字 | 子类构造函数 | 子类构造函数 )

类继承格式 : 使用 " : " 继承父类 ; 如果该父类有主构造函数 , 那么子类必须至少有一个主构造函数或次构造函数 , 子类构造函数下面会根据不同情况详细解析 ; //注意这里父类构造函数需要实际调用...子类有主构造函数 : 父类必须在主构造函数中初始化 , 子类 constructor() 可以省略 ; " : " 后 Father() 相当于调用了父类构造函数 , 将子类构造函数委托给父类构造函数执行...子类没有主构造函数 : 如果没有主构造函数 , 那么子类必须有次构造函数 , 子类需要在次构造函数中定义需要变量 , 其中参数 , 可以直接传递给后面 super ( ) 委托调用构造函数 ;...父类构造函数子类构造函数总结 ---- 子类构造函数最终委托 : 子类构造函数归根到底都要委托给父类构造函数 ; ① 子类构造函数 : 假如子类有主构造函数 , 该主构造函数肯定要委托父类构造函数执行...; ② 子类构造函数 : 此时子类构造函数都要委托子类构造函数执行 , 相当于间接委托父类主构造函数执行 ;

1.1K10

创建子类对象时,父类构造函数中调用被子类重写方法为什么调用子类方法?

static void main(String[] args) { A a = new A(); B b = new B(); } } 问题:为什么创建A对象时候父类会调用子类方法...但是:创建B对象父类会调用父类方法? 答案: 当子类被加载到内存方法区后,会继续加载父类到内存中。...如果,子类重写了父类方法,子类方法引用会指向子类方法,否则子类方法引用会指向父类方法引用。 如果子类重载了父类方法,则子类重载方法引用还指向子类方法。...如果子类方法没有重写也没有重载父类方法,则方法引用会指向父类方法。 当子类对象创建时,会先行调用父类构造方法(构造方法也是方法),虚拟机会在子类方法区寻找该方法并运行。...其结果是当编译时候,父类构造方法调用方法参数已经强制转换为符合父类方法参数了。 上边代码在编译前已经转换为下面这个样子了。

6.1K10

Lagrange插构造位移场函数

法就是一个从已知点近似计算未知点近似计算方法,即构造一个多项式函数,使其通过所有已知点,然后用求得函数预测位置点。...构造一个多项式li(x),让n=i时候li(x)=1,当n≠i时候li(x)=0,这样就保证了li(x)通过每一个(xi,yi)点,符合插原理。 ?...因此,对于n个节点一维单元,节点坐标为(xi,yi)(i=1,2,...,n),多项式插可达n-1阶,例如:n=2时可构造一次多项式。 ? ? ? 这样可以构造杆单元轴向位移(应变)场。...假定单元轴向位移按照线性变化,在自然坐标系下,单元内任意一点位移表达式为 ? ? 由此可看出,位移函数为线性函数,即在单元内以一个线性变化位移场模拟原位移场。...形函数,插位移函数及原位移函数图形如图所示: ?

1.4K50

CA1012:抽象类型不应具有公共构造函数

项 “” RuleId CA1012 类别 设计 修复是中断修复还是非中断修复 非中断 原因 类型为抽象类型并且具有公共构造函数。 默认情况下,此规则仅查看外部可见类型,但这是可配置。...规则说明 抽象类型构造函数只能由派生类型调用。 由于公共构造函数可创建类型实例,但无法创建抽象类型实例,因此具有公共构造函数抽象类型在设计上是错误。...如何解决冲突 若要解决此规则冲突,请将构造函数设置为受保护函数,或者不将该类型声明为抽象类型。 何时禁止显示警告 不禁止显示此规则发出警告。 抽象类型具有公共构造函数。...包含特定 API 图面 你可以根据代码库可访问性,配置要针对其运行此规则部分。...End Class // Violates this rule public abstract class Book { public Book() { } } 下面的代码片段将构造函数可访问性从

48020

js 中构造函数构造函数作用,构造函数和普通函数区别

4、构造函数返回 构造函数执行过程最后一步是默认返回 this 。言外之意,构造函数返回还有其它情况。 没有手动添加返回,默认返回 this。...手动添加一个基本数据类型返回,最终还是返回 this。...我们发现,虽然每位同学都有 name、age、sex这些属性, 但它们都是不同,那我们就把这些属性当做构造函数参数传递进去。...在使用对象字面量创建一系列同一类型对象时,这些对象可能具有一些相似的特征(属性)和行为(方法),此时会产生很多重复代码,而使用构造函数就可以实现代码复用。...逐个执行函数代码 D、将新建对象作为返回 6、构造函数返回默认是this 也有其他情况 。

3.4K10

子类A继承父类B, A a = new A(); 则父类B构造函数、父类B静态代码块、父类B非静态代码块、子类A构造函数子类A静态代码块、子类A非静态代码块 执行先后顺序是?

(1)子类A继承父类B, A a = new A(); 则: 父类B静态代码块->子类A静态代码块->父类B非静态代码块->父类B构造函数->子类A非静态代码块->子类构造函数 (2)若子类构造函数中显式调用了父类构造函数...,则调用该构造函数 class C { C() { System.out.print("C"); } } class A { C c = new C();...,那么就要调用构造方法来初始化该子类对象,但是该类继承自A,所以要先调用父类构造方法,这里通过super(“B”)显示调用了父类带参构造。...执行父类带参构造前要先对父类中对象进行初始化,对父类中c成员进行初始化,调用了C类无参构造,所以调用顺序为: 先调用C类无参构造 再调用A类带参构造 最后调用调用子类构造 (3...顺序为:父类静态变量, 父类静态代码块 ,子类静态变量,子类静态代码块。

2.1K30

构造函数没有返回是怎么赋值

个人原创100W+访问量博客:点击前往,查看更多 转自:艾小仙 众所周知,在java里是不能给构造函数写返回,如果在低版本编译器定义一个构造器写上返回可能会报错,高版本里面他就是一个普通方法。...可是如果构造函数没有返回,那么比如Test t = new Test()我们new一个对象时候是怎么赋值呢?...构造函数有返回吗 写一段代码测试一下: public class Test { public Test() { } public static void main...4: invokespecial #7 // Method "init":()V,调用构造函数,V代表void无返回,那么init代表什么含义?...init代表着虚拟机调用构造函数,现在情况很明显,构造函数返回类型是void,那么它究竟是怎么赋值呢?

1.6K20

【C++】拷贝构造函数调用时机 ② ( 对象作为函数参数 | 对象作为函数返回 )

另外一个 类实例对象 ; // 将一个对象赋值给另外一个对象 // 自动调用拷贝构造函数 Student s2 = s1; ③ 对象作为函数参数 : 类实例对象 以方式 传递给函数 , 不是以..., 使其内容与原对象完全相同 ; 二、对象作为函数参数 ---- 1、拷贝构造函数调用情况说明 类实例对象 以方式 传递给函数 , 不是以 指针 或 引用 方式 ; 这种情况 是 以 类...对象作为参数 void fun(Student s) { } 如果调用该函数 , 需要拷贝实参 , 将 实参副本 , 也就是对象 传递给函数形参 , 这个过程需要调用 Student 类 拷贝构造函数...; 然后 , 将创建实例对象 传递给 fun 函数 , 传递时由于传递是 对象 , 需要拷贝对象副本 , 拷贝副本时会自动调用 Student 类 拷贝构造函数 ; 调用带参数构造函数 调用拷贝构造函数...三、对象作为函数返回 ---- 1、拷贝构造函数调用情况说明 函数直接返回类实例对象 , 不是返回 指针 或 引用 ; 下面的代码 , 定义了函数 , 返回在函数内部创建 Student 类实例对象

16520

带右引用拷贝构造函数和运算符重载函数

考虑一个占用堆资源类对象拷贝构造和赋值运算符重载函数,当我们用一个临时对象去拷贝构造一个新对象或者赋值给一个已经存在对象时,会出现一下问题:如string类 #include ...到这里就引出了第一个主题,带右引用拷贝构造函数。因为临时对象是右。临时对象用完就要析构,那就把临时对象占用资源直接给新对象就好了。...这样做一方面避免了在原来拷贝构造函数需要首先申请空间,然后进行拷贝麻烦。另一方面避免临时对象析构时还有释放堆资源麻烦,一举两得!!!...*this; } delete[] mptr; mptr = s.mptr; s.mptr = nullptr; return *this; } 结论: 至此,通过一个例子我们总结出了带右引用拷贝构造函数和运算符重载函数所带来效率提升...在实际开发中,当出现一定要用临时对象作为返回,要用临时来进行赋值时,我们可以为其类实现带右引用拷贝构造函数和运算符重载函数,在程序效率上会得到很大提升。

73120
领券