摘要:如果里调用了一个成员方法,这个方法被子类了,当初始化一个子类实例时,父类的构造函数被的调用,此时父类构造函数的上下文里调用的成员方法,是父类的实现还是子类的实现你能不用运行代码,就能准确说出这些语句会打印什么出来呢测试测试结果测试
如果constructor里调用了一个成员方法,这个方法被子类override了,当初始化一个子类实例时,父类的构造函数被的调用,此时父类构造函数的上下文里调用的成员方法,是父类的实现还是子类的实现?
你能不用运行代码,就能准确说出这些语句会打印什么出来呢?
class ZCL_SUPER definition public create public . public section. methods CONSTRUCTOR . methods SET_I importing !IV_I type INT4 . protected section. private section. data MV_SUPER type INT4 . ENDCLASS. CLASS ZCL_SUPER IMPLEMENTATION. method CONSTRUCTOR. me->set_i( 100 ). endmethod. method SET_I. me->mv_super = iv_i. endmethod. ENDCLASS. class ZCL_SUB definition public inheriting from ZCL_SUPER final create public . public section. methods PRINT . methods SET_I redefinition . protected section. private section. data MV_SUB type I value 1 ##NO_TEXT. ENDCLASS. CLASS ZCL_SUB IMPLEMENTATION. method PRINT. WRITE: / " sub:" , mv_sub. endmethod. METHOD set_i. super->set_i( iv_i = iv_i ). me->mv_sub = iv_i. WRITE: / "mv_sub assigned by: " , iv_i. ENDMETHOD. ENDCLASS.
测试:
NEW zcl_sub( )->print( ).
测试结果:sub: 1
Javapublic class SuperClass { private int mSuperX; public SuperClass() { setX(99); } public void setX(int x) { mSuperX = x; } } public class SubClass extends SuperClass { private int mSubX = 1; public SubClass() {} @Override public void setX(int x) { super.setX(x); mSubX = x; System.out.println("SubX is assigned " + x); } public void printX() { System.out.println("SubX = " + mSubX); } }
test:
public static void main(String[] args) { SubClass sc = new SubClass(); sc.printX(); }
测试结果:
function SuperClass(){ this.setX(99); } SuperClass.prototype = { mSuperX : 0, setX : function(x){ this.mSuperX = x; } }; function SubClass(){ SuperClass.call(this); this.mSubX = 1; } SubClass.prototype = new SuperClass(); SubClass.prototype.setX = function(x){ SuperClass.prototype.setX(x); this.mSubX = x; console.log("SubX is assigned " + x); }; SubClass.prototype.print = function(){ console.log("SubX: " + this.mSubX); }
test:
var sub = new SubClass(); sub.print();
测试结果:
详细分析在我的SAP community博客里: A reminder for using constructor in OO world
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/52163.html
摘要:如果里调用了一个成员方法,这个方法被子类了,当初始化一个子类实例时,父类的构造函数被的调用,此时父类构造函数的上下文里调用的成员方法,是父类的实现还是子类的实现你能不用运行代码,就能准确说出这些语句会打印什么出来呢测试测试结果测试 如果constructor里调用了一个成员方法,这个方法被子类override了,当初始化一个子类实例时,父类的构造函数被的调用,此时父类构造函数的上下文里...
摘要:如果里调用了一个成员方法,这个方法被子类了,当初始化一个子类实例时,父类的构造函数被的调用,此时父类构造函数的上下文里调用的成员方法,是父类的实现还是子类的实现你能不用运行代码,就能准确说出这些语句会打印什么出来呢测试测试结果测试 如果constructor里调用了一个成员方法,这个方法被子类override了,当初始化一个子类实例时,父类的构造函数被的调用,此时父类构造函数的上下文里...
摘要:实现步骤非常简单,在标准程序的内创建一个隐式增强。禁止在测试服务器和生产服务器使用否则由此造成的一切负面后果,本人及概不负责。 最近Jerry在忙一个项目,技术栈换成了nodejs平台,语言换成了JavaScript,因为赶项目进度,一直没时间更新公众号。感谢大家的支持,关注人数还是慢慢地增长到了3000。 showImg(https://segmentfault.com/img/re...
阅读 999·2021-09-26 09:55
阅读 3533·2021-09-24 10:30
阅读 1344·2021-09-08 09:36
阅读 2534·2021-09-07 09:58
阅读 564·2019-08-30 15:56
阅读 743·2019-08-29 18:32
阅读 3537·2019-08-29 15:13
阅读 1827·2019-08-29 13:49