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

为什么BaseController的重载构造函数没有被执行?

BaseController的重载构造函数没有被执行的可能原因有以下几种:

  1. 构造函数未被正确调用:在实例化BaseController的子类时,可能没有显式地调用重载的构造函数。在子类的构造函数中,应该使用super关键字来调用父类的构造函数,以确保重载的构造函数被执行。
  2. 重载构造函数的参数不匹配:如果子类的构造函数中没有传递与重载构造函数相匹配的参数,那么重载构造函数将不会被执行。确保子类的构造函数中传递的参数与重载构造函数的参数列表匹配。
  3. 重载构造函数被其他构造函数覆盖:如果子类中定义了多个构造函数,并且其中一个构造函数没有调用重载的构造函数,那么重载构造函数将不会被执行。确保在子类的所有构造函数中都调用了重载的构造函数。
  4. 继承关系错误:如果BaseController的子类并非直接继承自BaseController,而是通过其他中间类间接继承自BaseController,那么重载构造函数可能会被中间类的构造函数覆盖而不被执行。确保子类直接继承自BaseController。

总结起来,要确保BaseController的重载构造函数被执行,需要在子类的构造函数中显式调用super关键字来调用父类的构造函数,并传递与重载构造函数相匹配的参数。

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

相关·内容

为什么 Python 没有函数重载?如何用装饰器实现函数重载

函数重载指的是有多个同名函数,但是它们签名或实现却不同。当调用一个重载函数 fn 时,程序会检验传递给函数实参/形参,并据此而调用相应实现。...当我们像 area(7) 这样调用函数 area 时,它会调用第二个函数,而 area(3,4) 则会调用第一个函数为什么 Python 中没有函数重载? Python 不支持函数重载。...函数函数接收参数量 被重写__call__方法会调用被封装函数,并返回计算值(这没有啥特别的)。...我们没有更改 Python 默认行为,因此在原生命名空间中,同名函数只有一个。 这个 get 函数决定了会调用函数哪个实现(如果重载了的话)。...") # 调用被封装函数,并返回调用结果 return fn(*args, **kwargs) 该方法从虚拟命名空间中获取正确函数,如果没有找到任何函数,它就抛出一个 Exception

3K10

Java系列:构造函数重载和普通函数那些事~

关于构造函数,我们下面会说到它重载,不知道大家有没有想到既然木有返回值,那么我们如果直接把{}括号拿出来使用呢?这就会介绍到匿名构造块,它作用也是初始化对象。...一.构造方法之重载 上次我们说到了构造函数以及它简单使用方法,比如带有不同参数列表构造方法可以用来实现不同方法。 至于为什么会有重载这么一个说法呢?...类中可以有很多个构造函数,但我们知道它们函数参数是不一样;多个构造函数加上构造函数重载,这样可以衍生出很多个函数,当我们在初始化对象时,就可以表达出对象多种初始化行为,这也是构造函数重载一个作用...如下有两种方法调用方式: 本类中方法调用:方法名(参数列表) 外部类中方法调用:调用类对象.方法名(参数列表) 构造函数和普通方法区别: 名称 具体区别 函数名 1.构造函数没有返回值类型...2.普通函数是有返回值类型,即使函数没有返回值,返回值类型也要写上void 返回值类型 1.构造函数函数名必须要类名一致 2.普通函数函数名只要符合标识符命名规则即可 调用方式 1.构造函数是在创建对象时候由

73540

C++ 构造函数运用,继承、派生时重载方式

构造函数 c++在进行实例化时候通常需要使用构造函数没有显示构造函数时候,系统会默认一个所有参数为空默认构造函数。...派生类中构造函数 在派生类中使用构造函数时,需要同时构造基类构造函数,如果同时继承多个基类,则需要依次构造基类。...在没有进行基类构造时候,c++会默认使用基类默认构造函数进行构造,但如果不满足这样条件,就会报错。...有些时候我们可能会需要一些变种构造函数,也就是重载。譬如说当我们基于Matrix设计一个九宫格类时候,实际上matrix行和列都是固定3x3.我们并不需要这两个参数来初始化。...这样的话,我们就可以使用单参数形式重载九宫格类构造函数: template class sMatrix : public Matrix{ private: int

69940

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

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

74120

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

众所周知,在java里是不能给构造函数写返回值,如果在低版本编译器定义一个构造器写上返回值可能会报错,高版本里面他就是一个普通方法。...可是如果构造函数没有返回值,那么比如Test t = new Test()我们new一个对象时候是怎么赋值呢?...我在书里找到这样一段话: 在 Java 虚拟机层面上,Java 语言中构造函数是以一个名为init特殊实例初始化方法形式出现,init这个方法名称是由编译器命名,因为它并非一个合法 Java...类或接口初始化方法由 Java 虚拟机自身隐式调用,没有任何虚拟机字节码指令可以调用这个方法,只有在类初始化阶段中会被虚拟机自身调用。...init代表着虚拟机调用构造函数,现在情况很明显,构造函数返回类型是void,那么它究竟是怎么赋值呢?

1.7K20

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

个人原创100W+访问量博客:点击前往,查看更多 转自:艾小仙 众所周知,在java里是不能给构造函数写返回值,如果在低版本编译器定义一个构造器写上返回值可能会报错,高版本里面他就是一个普通方法。...可是如果构造函数没有返回值,那么比如Test t = new Test()我们new一个对象时候是怎么赋值呢?...我在书里找到这样一段话: 在 Java 虚拟机层面上,Java 语言中构造函数是以一个名为init特殊实例初始化方法形式出现,init这个方法名称是由编译器命名,因为它并非一个合法 Java...类或接口初始化方法由 Java 虚拟机自身隐式调用,没有任何虚拟机字节码指令可以调用这个方法,只有在类初始化阶段中会被虚拟机自身调用。...init代表着虚拟机调用构造函数,现在情况很明显,构造函数返回类型是void,那么它究竟是怎么赋值呢?

1.6K20

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

众所周知,在java里是不能给构造函数写返回值,如果在低版本编译器定义一个构造器写上返回值可能会报错,高版本里面他就是一个普通方法。...可是如果构造函数没有返回值,那么比如Test t = new Test()我们new一个对象时候是怎么赋值呢?...我在书里找到这样一段话: 在 Java 虚拟机层面上,Java 语言中构造函数是以一个名为init特殊实例初始化方法形式出现,init这个方法名称是由编译器命名,因为它并非一个合法 Java...类或接口初始化方法由 Java 虚拟机自身隐式调用,没有任何虚拟机字节码指令可以调用这个方法,只有在类初始化阶段中会被虚拟机自身调用。...init代表着虚拟机调用构造函数,现在情况很明显,构造函数返回类型是void,那么它究竟是怎么赋值呢?

2.1K00

【C++】运算符重载 ⑨ ( 等号 = 运算符重载 | 调用默认浅拷贝构造函数情况分析 | 等号 = 运算符重载 与 拷贝构造函数 各自使用场景 | 等号 = 操作符重载步骤 )

, 并支持链式操作 ; 一、等号 = 运算符重载 ---- 1、调用默认浅拷贝构造函数情况分析 C++ 编译器 为 类 提供 默认 拷贝操作 , 是对 成员变量 简单拷贝 , 是 浅拷贝 ;...拷贝构造函数 各自使用场景 等号 = 运算符重载 与 拷贝构造函数 各自使用场景 : 拷贝构造函数 : 如果 使用对象 为一个 新对象 进行初始化 , 调用是拷贝构造函数 ; 等号 = 运算符重载 :...如果 使用对象 为一个已存在对象 重新进行赋值 , 调用是 等号运算符 重载运算符方法 ; 3、= 操作符重载步骤 使用 成员函数 实现 等号 = 运算符重载 : 首先 , 写出函数名 , Student...= NULL) { free(m_name); m_name = NULL; } cout << "调用析构函数" << endl; } // 该类没有定义拷贝构造函数 ,...(); s2.toString(); // 执行时没有问题 , 两个对象都可以正常访问 // 但是由于拷贝时 执行是浅拷贝 // 浅拷贝 字符串指针时 , 直接将指针进行拷贝 , 没有拷贝具体

23020

一个以前没有注意问题:java构造函数执行顺序

昨天在改一处代码时发现执行过程和预想不一样,仔细探究才发现是构造器执行顺序问题.(汗自己一下,基础不够扎实) 特地做了一些尝试然后把java构造执行顺序整理出来....: FatherProp is construct Father is construct SonProp is construct Son is construct 由此不难看出java类初始化时构造函数调用顺序...: (1)初始化对象存储空间为零或null值; (2)按顺序分别调用父类成员变量和实例成员变量初始化表达式; (3)调用父类构造函数;(如果实用super()方法指定具体某个父类构造函数则使用指定那个父类构造函数...) (4)按顺序分别调用类成员变量和实例成员变量初始化表达式; (5)调用类本身构造函数。...); 也就是无论你,new 多少个 TestClass 实例,它们对应着同一个 TestClass Class 实例,也就是为什么很多地方把静态方法、静态属性说成是类方法、类属性,其实质就是在

99420

一个以前没有注意问题:java构造函数执行顺序

昨天在改一处代码时发现执行过程和预想不一样,仔细探究才发现是构造器执行顺序问题.(汗自己一下,基础不够扎实) 特地做了一些尝试然后把java构造执行顺序整理出来....: FatherProp is construct Father is construct SonProp is construct Son is construct 由此不难看出java类初始化时构造函数调用顺序...: (1)初始化对象存储空间为零或null值; (2)按顺序分别调用父类成员变量和实例成员变量初始化表达式; (3)调用父类构造函数;(如果实用super()方法指定具体某个父类构造函数则使用指定那个父类构造函数...) (4)按顺序分别调用类成员变量和实例成员变量初始化表达式; (5)调用类本身构造函数。...); 也就是无论你,new 多少个 TestClass 实例,它们对应着同一个 TestClass Class 实例,也就是为什么很多地方把静态方法、静态属性说成是类方法、类属性,其实质就是在

67610

一个以前没有注意问题:java构造函数执行顺序

昨天在改一处代码时发现执行过程和预想不一样,仔细探究才发现是构造器执行顺序问题.(汗自己一下,基础不够扎实) 特地做了一些尝试然后把java构造执行顺序整理出来....: FatherProp is construct Father is construct SonProp is construct Son is construct 由此不难看出java类初始化时构造函数调用顺序...: (1)初始化对象存储空间为零或null值; (2)按顺序分别调用父类成员变量和实例成员变量初始化表达式; (3)调用父类构造函数;(如果实用super()方法指定具体某个父类构造函数则使用指定那个父类构造函数...) (4)按顺序分别调用类成员变量和实例成员变量初始化表达式; (5)调用类本身构造函数。...); 也就是无论你,new 多少个 TestClass 实例,它们对应着同一个 TestClass Class 实例,也就是为什么很多地方把静态方法、静态属性说成是类方法、类属性,其实质就是在

63320

一个以前没有注意问题:java构造函数执行顺序

昨天在改一处代码时发现执行过程和预想不一样,仔细探究才发现是构造器执行顺序问题.(汗自己一下,基础不够扎实) 特地做了一些尝试然后把java构造执行顺序整理出来....: FatherProp is construct Father is construct SonProp is construct Son is construct 由此不难看出java类初始化时构造函数调用顺序...: (1)初始化对象存储空间为零或null值; (2)按顺序分别调用父类成员变量和实例成员变量初始化表达式; (3)调用父类构造函数;(如果实用super()方法指定具体某个父类构造函数则使用指定那个父类构造函数...) (4)按顺序分别调用类成员变量和实例成员变量初始化表达式; (5)调用类本身构造函数。...); 也就是无论你,new 多少个 TestClass 实例,它们对应着同一个 TestClass Class 实例,也就是为什么很多地方把静态方法、静态属性说成是类方法、类属性,其实质就是在

95220

如何将没有复制或移动构造函数对象放入vector容器

原因是因为std::vector容器插入一定会调用类对象构造函数或者移动构造函数。...说一下为什么会有这个问题,因为不想用指针,我想直接通过类对象本身RAII机制来实现资源控制,智能指针是一个解决方案,不过智能指针是写起来很繁琐,终究比不上值类型方便。...不过值类型要用好还是很麻烦,比如这里没有复制或移动构造函数对象插入到std::vector容器中问题。 经过查阅资料,总共有四种解决方案: 使用默认构造函数,并且初始化时确定容器大小。...使用智能指针方案还是不错,只要你愿意使用智能指针语法。笔者这里使用时第三种,更换容器为std::deque。...因此,在插入时std::deque不像std::vector那样需要移动或者拷贝构造,是直接初始化构造在分配空间中

16250

c++私有变量和公有变量_没有与指定类型匹配重载函数实例

accessor和mutator主要用来实现数据封装,有了accessor和mutator,我们就可以将数据成员设为私有,所有对它们读写操作都通过这两个函数来实现。...public: int getId();//accessor function,是只读性质函数 void setId(int id);//mutator function,是只写性质函数...}; 函数形参与类私有成员重名解决方法 ---- #include class retangle{ private: double width; double...会出现编译错误,原因大概是,编译器把两个width和height都当成是传进函数参数。...setHeight(double height) { this->height = height; return; } }; 通过引用this指针,可以明确复制号左操作数是调用函数对象里面的

1.3K20

构造函数为什么一般不定义为虚函数?而析构函数一般写成虚函数原因 ?

浏览量 3 1、构造函数不能声明为虚函数 1)因为创建一个对象时需要确定对象类型,而虚函数是在运行时确定其类型。...而在构造一个对象时,由于对象还未创建成功,编译器无法知道对象实际类型,是类本身还是类派生类等等 2)虚函数调用需要虚函数表指针,而该指针存放在对象内存空间中;若构造函数声明为虚函数,那么由于对象还未创建...,还没有内存空间,更没有函数表地址用来调用虚函数构造函数了 2、析构函数最好声明为虚函数,首先析构函数可以为虚函数,当析构一个指向派生类基类指针时,最好将基类析构函数声明为虚函数,否则可以存在内存泄露问题...如果析构函数不被声明成虚函数,则编译器实施静态绑定,在删除指向派生类基类指针时,只会调用基类析构函数而不调用派生类析构函数,这样就会造成派生类对象析构不完全。子类析构时,要调用父类析构函数吗?...析构函数调用次序时先派生类后基类。和构造函数执行顺序相反。并且析构函数要是virtual,否则如果用父类指针指向子类对象时候,析构函数静态绑定,不会调用子类析构。

61610

箭头函数与普通函数(function)区别是什么?构造函数(function)可以使用 new 生成实例,那么箭头函数可以吗?为什么

基本不同 1.写法不同,箭头函数使用箭头定义,普通函数没有 .箭头函数都是匿名函数,普通函数可以有匿名函数,也可以有具体名函数,但是箭头函数都是匿名函数。...在普通函数中,this总是指向调用它对象,如果用作构造函数,this指向创建对象实例。箭头函数没有this,声明时捕获其所在上下文this供自己使用。...所以箭头函数结合call(),apply()方法调用一个函数时,只传入一个参数对this没有影响。...obj x fn1.apply(obj); // obj x fn2.call(obj); // window x fn2.apply(obj); // window x 4.箭头函数不可以做构造函数...,不能使用new 关键字,因为new关键字是调用函数对象constructor属性,箭头函数没有该属性,所以不能new function fn1(){ console.log

1.8K10

关于Java构造函数(Constructor)常见问题总结1 为什么调用子类构造方法时候,默认会调用父类构造方法2 常见错误:Implicit super constructor is und

编译器错误是因为默认super()无参构造函数没有定义。在Java中,如果一个类没有定义构造函数,编译器会自动插入一个默认无参构造函数。...上一小节,我们知道,如果子类构造函数中,没有显示调用父类构造函数,那么,编译器就会插入super(),也就是自动调用无参构造函数。但是此时,父类没有无参构造函数,所以就会报错了。...Paste_Image.png 构造函数使用规则 简单说,在使用时候,子类构造函数必须调用父类构造函数,不管有没有显示声明。所以,被调用父类构造函数,一定在定义好!...为什么Java在一个类已经实现了一个带参构造函数时候,不实现默认无参构造函数? 这是个很有趣问题。...我们知道如果在一个类中没有声明一个构造函数,那么编译器会隐式帮我们实现一个无参构造函数,但如果我们一旦一个构造函数,不管带不带参数,那么编译器都不会提供默认构造函数,所以这么做原因是为什么呢?

2.7K41

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

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

6.1K10
领券