首页
学习
活动
专区
工具
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

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

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

    81540

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

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

    71940

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

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

    76620

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

    众所周知,在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.7K20

    【C++】类和对象(中):类的默认成员函数,构造函数、析构函数、拷贝构造函数、运算符重载

    1.类的默认成员函数 默认成员函数就是用户没有显示实现,编译器会自动生成的成员函数。...这里解释一下为什么拷贝构造第一个参数传参方式必须是引用。 首先我们要知道,C++规定传值传参要调用拷贝构造,没有为什么,就是规定。比如说下面这个f1函数。...这也就是为什么我在这一小节的开头并没有自己写拷贝构造函数的代码但依然可以进行拷贝构造。...比如两个日期加就没有意义,两个日期减就有意义,两个日期减就是相差的天数。 5.1 赋值运算符重载 赋值运算符重载是一个默认成员函数,用于完成两个已经存在的对象直接的拷贝赋值。...3.没有显示实现时,编译器会自动生成一个默认赋值运算符重载,默认赋值运算符重载行为跟默认拷贝构造函数类似。 4.

    11410

    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(); // 执行时没有问题 , 两个对象都可以正常访问 // 但是由于拷贝时 执行的是浅拷贝 // 浅拷贝 字符串指针时 , 直接将指针进行拷贝 , 没有拷贝具体的值

    27320

    C++新旅程:类的拷贝构造函数 、赋值运算符重载 和const成员函数

    拷贝构造函数1.1概念拷贝构造:用同类型的已经存在的对象,拷贝给另一个要创建初始化的对象。...1.2特征(1)拷贝构造函数是构造函数的一个重载形式(2)参数有且只有一个,必是类类型对象的引用,使用传值编译器会直接报错(因为会引发无穷递归调用1.3拷贝构造函数典型调用场景使用已存在对象创建新对象函数参数类型为类类型对象函数返回值类型为类类型对象简单代码示例一...C++为了增强代码的可读性引入了运算符重载,运算符重载是具有特殊函数名的函数,也具有其返回值类型,函数名字以及参数列表,其返回值类型与参数列表与普通的函数类似。...:一个已经存在的对象,拷贝复制给另一个已经存在的对象(要区别拷贝构造)注意:1、作为类成员函数重载时,其形参看起来比操作数数目少1,因为成员函数的第一个参数为隐藏的this。...3、 用户没有显式实现时,编译器会生成一个默认赋值运算符重载,以值的方式逐字节拷贝。内置类型成员变量是直接赋值的,而自定义类型成员变量需要调用对应类的赋值运算符重载完成赋值。

    8210

    一个以前没有注意的问题: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 实例,也就是为什么很多地方把静态方法、静态属性说成是类的方法、类的属性,其实质就是在

    1K20

    一个以前没有注意的问题: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 实例,也就是为什么很多地方把静态方法、静态属性说成是类的方法、类的属性,其实质就是在

    68810

    一个以前没有注意的问题: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 实例,也就是为什么很多地方把静态方法、静态属性说成是类的方法、类的属性,其实质就是在

    95720

    一个以前没有注意的问题: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 实例,也就是为什么很多地方把静态方法、静态属性说成是类的方法、类的属性,其实质就是在

    65520

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

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

    19350

    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的,否则如果用父类的指针指向子类对象的时候,析构函数静态绑定,不会调用子类的析构。

    70210

    箭头函数与普通函数(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

    2K10
    领券