基类的构造函数能不能被继承?为什么?
书上说基类的构造函数不能被子类继承。但是子类分明可以调用基类构造函数的啊。那么调用和继承有什么区别?怎感觉没啥区别呢。。...
书上说基类的构造函数不能被子类继承。
但是子类分明可以调用基类构造函数的啊。那么调用和继承有什么区别?怎感觉没啥区别呢。。 展开
但是子类分明可以调用基类构造函数的啊。那么调用和继承有什么区别?怎感觉没啥区别呢。。 展开
2个回答
展开全部
父类(基类)被子类继承后,要实例化(new,应该叫实例化吧?)一个子类(派生类)的时候,编译器会自动帮调用父类的无参构造方法来实例化一个父类。如果父类写了一个含参数的构造方法的话,那么系统不会帮写一个空的无参构造方法,除非自己手动写了一个无参的构造方法。因此如果父类只写了含参构造方法而没有写无参构造方法的话,或者想调用含参的构造方法,那么得在子类体的第一行显示调用父类的含参构造方法,用super关键字。
因此可以认为当写了子类后编译器会默认帮在子类体的第一行写上父类的无参构造方法。当然,如果显示调用了就不会帮你写了。
想cpp里的拷贝构造函数,析构函数这种应该类似的道理。
应该看看类的实例化顺序。
因此可以认为当写了子类后编译器会默认帮在子类体的第一行写上父类的无参构造方法。当然,如果显示调用了就不会帮你写了。
想cpp里的拷贝构造函数,析构函数这种应该类似的道理。
应该看看类的实例化顺序。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询