------super关键字------
        
        super用途:在子类中访问超类“被隐藏的成员变量(无论是否静态)和静态方法”以及“被重写的实例方法”。这里的超类必须是“直接超类”,即子类之上最近的超类。
        super的用法:
        ①在子类构造方法中调用超类的构造方法,用“super(ParamList)”的方式调用,ParamList根据超类构造方法而定,可以为空。另外super(ParamList)必须是子类构造方法的第一句。
        ②当超类的成员变量因与子类的成员变量同名而被隐藏时(成员变量隐藏与是否静态无关),可用"super.memberVariableName"来访问超类的成员变量。
            注意:有些人说当超类的成员变量与子类某方法的局部变量或参数同名时,也属于被隐藏。那么一旦离开该方法隐藏还成立吗,显然这种说法是错误的。隐藏概念只限于成员变量范围,方法体内的局部变量与成员变量同名属于下面的this要讨论的内容。
                         假设有超类parent,其中有成员变量A,子类child,其中有方法method(type A)存在:
                        1)如果子类没有隐藏超类成员变量A,在method(type A)中,无论使用this.A还是super.A都是一样的,都会访问超类成   员变量A;(this.A就是继承下来的,换句话说,对于自然继承下来(没有隐藏/重写)的成员变量甚至是方法,super.memberName=this.membername)
                        2)如果子类有成员变量A隐藏了超类成员变量A,在method(type A)中,super.A=parent.A,this.A=child.A,两者有区别。
        ③当超类的静态方法/实例方法被子类隐藏/重写时,可使用"super.methodName(ParamList)"来访问超类方法。对于静态方法而言,这没什么奇怪,对于实例方法而言,这种用法使得超类被重写的方法在子类中可见。

最后需要注意,super关键字不能在静态方法中使用!

------this关键字------

this的用途:引用对象本身。
当一个对象创建后,Java虚拟机就会给这个对象分配一个引用自身的指针,这个指针的名字就是this。因此,this只能在类中的非静态方法中使用,静态方法和静态的代码块中绝对不能出现this。并且this只和特定的对象关联,而不和类关联,同一个类的不同对象有不同的this。
         this用法:
         ①在构造方法中,用this(ParamList)调用自己的另一个构造方法,this(ParamList)必须放在第一句位置!此用法只限于在构造方法中使用。
         ②某方法的参数或局部变量与某个成员变量同名时,在该方法中要访问该成员变量需要用“this.memberVariableName”的形式。
         ③某方法中需要引用其所属类的当前对象时,直接用this来引用当前对象。
示例代码:

  1. import java.lang.reflect.Field;
  2. import java.lang.reflect.Modifier;
  3. class A {
  4. int x;
  5. static double y;
  6. char z;
  7. A(char z) {
  8. this.z = z; // this访问成员变量,以区分同名参数
  9. }
  10. A(double newy, char newz) {
  11. double y = newy; // this访问成员变量,以区分同名局部变量
  12. char z = newz;
  13. this.y = y; // 因y是静态成员变量,最好使用className.staticMemberVarName即A.y访问
  14. this.z = z;
  15. }
  16. A(int a, double b, char c) {
  17. this(b, c);// 使用this(paramList)调用另一个构造方法必须放在第一句位置
  18. this.x = a;// 此处无法再使用this(x);理由同上
  19. }
  20. void OutPut() {
  21. if (this.equals(this))// this作为对象引用使用,当然此条件永远=true
  22. System.out.println("我是类" + GetClassName() + "的方法"
  23. + GetInvokeMethodName());
  24. }
  25. String GetClassName() {
  26. return this.getClass().getName();
  27. }
  28. String GetInvokeMethodName() {
  29. String TempName = new Exception().getStackTrace()[1].getMethodName();
  30. return TempName;
  31. }
  32. static void showStaticFieldValue(Object obj) throws Exception { //
  33. Field fields[] = obj.getClass().getDeclaredFields();
  34. String fieldName, fieldModifier, fieldType;
  35. Object val;
  36. for (int i = 0; i < fields.length; i++) {
  37. Field field = fields[i];
  38. if (field.toString().indexOf("static") != -1) {
  39. // System.out.println(field.toString());
  40. fieldName = field.getName();
  41. fieldType = field.getType().getName();
  42. fieldModifier = Modifier.toString(field.getModifiers());
  43. field.setAccessible(true);
  44. val = field.get(obj);
  45. System.out.println(fieldModifier + " " + fieldType + " "
  46. + fieldName + " = " + val);
  47. }
  48. }
  49. }
  50. void getStaticFieldValue() {
  51. try {
  52. showStaticFieldValue(this);
  53. } catch (Exception e) {
  54. }
  55. }
  56. }
  57. class B extends A {
  58. static double x;// 隐藏超类A的成员变量x
  59. int y = (int) this.x + 1;// 隐藏超类A的成员变量y,有人说this必须在方法体中使用,无情的击破其谣言。
  60. // 继承了超类A的成员变量z,仍为char z;
  61. B(char c) {
  62. super(c);/*
  63. * super(c)调用超类构造函数的目的在于初始化自然继承的超类成员,若子类完全隐藏了超类的成员变量, 则可以不用super
  64. * super(ParamList)访问超类构造函数 疑问: 1.类B隐藏且改变了类A的成员变量,
  65. * super(b)是否仅仅改变了B中包含的A对象的值, 而B中的static double x的值仍然为默认值?(待验证)
  66. * 2.java的构造方法属于实例方法还是静态方法?
  67. */
  68. x = super.y + 1.0;// super访问超类被隐藏的成员变量double y,也可以写成A.y
  69. y = super.x;// super访问超类被隐藏的成员变量int x
  70. }
  71. String GetClassName() {// 重写超类A的GetClassName()
  72. return "类类类BBB";
  73. }
  74. String GetInvokeMethodName() {// 重写超类A的GetInvokeMethodName()
  75. return "方法名称方法名称方法名称";
  76. }
  77. void OutPut() { // 重写超类的OutPut实例方法.
  78. System.out.println("super调用超类被重写的两个方法输出:类名="
  79. + super.GetClassName() + ",方法名=" + super.GetInvokeMethodName());// super调用超类的实例方法
  80. System.out.println("用类B的重写方法输出:类名=:" + GetClassName() + ","
  81. + ",方法名="+GetInvokeMethodName());// 调用自己的方法
  82. }
  83. static void showStaticFieldValue(Object obj) throws Exception { // 隐藏超类的静态方法
  84. System.out.println("static Field doulbe x=" + x);
  85. }
  86. void getStaticFieldValue() {
  87. try {
  88. System.out.println("super调用超类A的方法输出静态成员变量");
  89. super.showStaticFieldValue(this); // super调用超类被隐藏的静态方法
  90. System.out.println("类B自己的方法输出静态成员变量");
  91. showStaticFieldValue(this);// 类B自己的方法
  92. } catch (Exception e) {
  93. }
  94. }
  95. }
  96. class Example3_15 {
  97. public static void main(String[] args) {
  98. A myA = new A(8, 6.0, 'k');
  99. B myB = new B('哦');
  100. myA.getStaticFieldValue();
  101. myA.OutPut();
  102. System.out.println("====================");
  103. myB.getStaticFieldValue();
  104. myB.OutPut();
  105. }
  106. }

java的super和this关键字用法总结的更多相关文章

  1. Java中 final static super this instanceof 关键字用法

    一.final关键字 final可以修饰变量.方法及类: 1.当定义一个final变量时,jvm会将其分配到常量池中,其所修饰的对象只能赋值一次,对基本类型来说是其值不可变,引用类型(包括作为函数形参 ...

  2. super,this关键字用法 Java

    super 用法 1.调用父类变量2.调用父类方法3.子类构造方法第一句 this 用法 super关键字用来访问父类内容, this 关键字用来访问本类中的内容, 有三种用法 1.在本类的成员方法中 ...

  3. java中super的两种用法

    通过用static来定义方法或成员,为我们编程提供了某种便利,从某种程度上可以说它类似于C语言中的全局函数和全局变量.但是,并不是说有了这种便利,你便可以随处使用,如果那样的话,你便需要认真考虑一下自 ...

  4. Java中super的几种用法并与this的区别

    1. 子类的构造函数如果要引用super的话,必须把super放在函数的首位. class Base { Base() { System.out.println("Base"); ...

  5. java中super的几种用法,与this的区别

    1. 子类的构造函数如果要引用super的话,必须把super放在函数的首位. class Base { Base() { System.out.println("Base"); ...

  6. 关于java的continue、break关键字用法

    一 明确两个概念 循环:是指按照规定次数重复执行某一操作的全过程:其关键语句有for. foreach.while.do while 迭代:是指循环过程中单次操作,1次循环由n次迭代构成 二 用法归纳 ...

  7. Java中Super和final关键字以及异常类

    1.final类不能有子类,也就谈不上继承的说法,如果用final修饰成员变量或者局部变量,那成了常量需要制定常量的值. 2.对象的上转型对象,上转型对象不能操作子类新增的成员变量,不能调用子类新增的 ...

  8. Python面试题之Python和Java中Super方法的区别

    python 的 super 是一个函数,需要两个参数,第一个参数是类,第二个参数是实例,返回值是一个类对象. 其意义是:站在参数2这个实例的角度看去, 参数1这个类的‘父亲’是谁,把‘父亲’返回. ...

  9. Java中的两个关键字——super、this

    Java中的两个关键字——super.this 神话丿小王子的博客主页 一.super super 是java中方的一个关键字,用它可以引用父类中的成员: super可用于访问父类中定义的属性 sup ...

随机推荐

  1. Java快速排序和归并排序详解

    快速排序 概述 快速排序算法借鉴的是二叉树前序遍历的思想,最终对数组进行排序. 优点: 对于数据量比较大的数组排序,由于采用的具有二叉树二分的思想,故排序速度比较快 局限 只适用于顺序存储结构的数据排 ...

  2. 读博 在没有导师PUSH的情况下该何去何从?

    读博已有两月之久,与导师也是仅有的一面之缘,短短数分钟谈话大致总结便是看看基础知识,再然后就没有什么了,突然之间有些小懵逼.突然间感慨这就是我的博士生涯的生活,这就没有啦,以后就这么过啦?在读博士之前 ...

  3. 【机器学习算法】Boostrapping算法

    参考 1.AdaBoost从原理到实现: 完

  4. linux-锁屏时间设置

    系统:ubuntu16.04 操作步骤 设置setting -> System Settings -> Brightness&lock, 在界面中选择想要的设置即可: 参考 1.百 ...

  5. CF1083(div1)

    A. The Fair Nut and the Best Path 题意:给定有点权,有边权的树,让你选择一条链(也可以是只有一个点),使得点权之和-边权最大. 思路:裸的树形DP,我们用dp[i]表 ...

  6. 【洛谷P1462】【二分+堆优化dij】

    题目描述 在艾泽拉斯,有n个城市.编号为1,2,3,...,n. 城市之间有m条双向的公路,连接着两个城市,从某个城市到另一个城市,会遭到联盟的攻击,进而损失一定的血量. 每次经过一个城市,都会被收取 ...

  7. ACM中的取模

    取模本身的性质:(之前有一篇博客写过)三则运算(+,-,*)过程中的取模与最后的取模一样(前提是最后不超long long(或int) 范围,所以为防止超范围,直接对三则运算中的过程取模) 然后就是A ...

  8. hdu 5311(暴力)

    题意:要求在一个字符串中找出三段,然后能拼成一个固定的单词,问是否可行 BC周年庆第二题,我枚举了那个单词的切断位置,然后到给的字符串里分别找,然后就没有然后了``` #include<stdi ...

  9. HBase scan shell操作详解

    创建表 create 'test1', 'lf', 'sf' lf: column family of LONG values (binary value) -- sf: column family ...

  10. PostgREST docker-compose 试用

    PostgREST 是一款很不错的直接将pg 数据库暴露为restapi ,使用了基于行级别安全访问控制, 比较全的restapi 查询以及集成了swagger openapi docker-comp ...