java创建子类对象设置并调用父类的变量操作

通过子类调用父类的变量,有两种方法:

1、把父类的变量设置成public:

package triangle.opengl.wlz.stu.childusefathervariable;
import android.util.Log;
public class BasePublicVariable {
  private String TAG = getClass().getName();
  public int data;
  public void ptData(){
    Log.d(TAG, "ptData: " + data);
  }
}

当我们这样做时,需要时直接在对象中设置这个变量的值就可以了,子类不需要任何处理:

package triangle.opengl.wlz.stu.childusefathervariable;
import triangle.opengl.wlz.stu.childusefathervariable.BasePublicVariable;
public class ChildPublicVariable extends BasePublicVariable {
}

2、通过构造方法透传:

package triangle.opengl.wlz.stu.childusefathervariable;
import android.util.Log;
public class BaseVariableInConstructed {
  private String TAG = getClass().getName();

  private int data;
  public BaseVariableInConstructed(int data){
    this.data = data;
  }
  public void ptData(){
    Log.d(TAG, "ptData: " + data);
  }
}

这时,子类可以使用super方法,调用父类的构造方法:

package triangle.opengl.wlz.stu.childusefathervariable;

import android.util.Log;

public class ChildVaralbleInConstructed extends BaseVariableInConstructed {
  public ChildVaralbleInConstructed(int data) {
    super(data);
  }
}

最终的使用方式:

package triangle.opengl.wlz.stu.childusefathervariable;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
public class MainActivity extends AppCompatActivity {

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    test();
  }

  private void test(){
    ChildVaralbleInConstructed base = new ChildVaralbleInConstructed(100);
    base.ptData();

    ChildPublicVariable base2 = new ChildPublicVariable();
    base2.data = 10;
    base2.ptData();
  }
}

补充:Java子类访问父类私有变量的思考

示例如下:

父类User,包含私有变量name和money;

以及两个构造函数和基本的getter方法。

public class User {
  public User() {
  }
  public User(String name, int money) {
    this.name = name;
    this.money = money;
  }
  public String getName() {
    return name;
  }
  public int getMoney() {
    return money;
  }
}

子类Manager继承User

public class Manager extends User {
  public Manager() {
  }
  public Manager(String name, int money) {
    super(name, money);
  }
  private String name;
  private int money;
  public void show(){
    System.out.println("我是"+this.name+",我有"+this.money+"元钱");
    System.out.println("我是"+this.getName()+",我有"+this.getMoney()+"元钱");
    System.out.println("我是"+super.getName()+",我有"+super.getMoney()+"元钱");
  }
}

主类ClassDemo新建一个Manager对象,并调用其show()函数。

public class ClassDemo {
  public static void main(String[] args) {
    Manager m=new Manager("q",1);
    m.show();
  }
}

结果如下

我是null,我有0元钱---1

我是q,我有1元钱------2

我是q,我有1元钱------3

其中结果1容易理解,本类中的两个变量没有初始化,返回的是默认值。

结果2一开始感觉很困惑,子类继承了父类的getName()和getMoney(),可并没有继承私有变量name和money,这里返回的值是谁的呢?

之后了解了一下这一部分的内存原理,原来新建子类时,会先在堆中新建一个父类,父类的变量和方法,以及子类独有的变量和方法,二者共同组成了子类空间。

所以,新建子类后,父类中的private变量虽然不能被子类继承,但却是真实存在的,只是不可被直接访问,只能间接使用。

结果2中,Manager对象其实在创建时就已经在构造函数中通过super(name,money)给name和mongey这两个父类私有变量赋值了。而在使用this.getName()方法时,该方法是从父类继承,所以方法内使用的变量也是父类的这两个私有变量,所以在结果2中返回的是自定义的两个值。

结果3中,super()直接通过父类调用getter方法,返回值当然也是两个父类私有变量。

不过,如果在子类Manager中重写getter方法,结果2就发生了改变。

public class Manager extends User {
  public Manager() {
  }
  public Manager(String name, int money) {
    super(name, money);
  }
 /*****************************新增重写方法***************************/
  @Override
  public String getName() {
    return name;
  }
  @Override
  public int getMoney() {
    return money;
  }
 /*****************************************************************/
  private String name;
  private int money;
  public void show(){
    System.out.println("我是"+this.name+",我有"+this.money+"元钱");
    System.out.println("我是"+this.getName()+",我有"+this.getMoney()+"元钱");
    System.out.println("我是"+super.getName()+",我有"+super.getMoney()+"元钱");
  }
}

我是null,我有0元钱---1

我是null,我有0元钱---2

我是q,我有1元钱------3

因为现在本类Manager中已经有了getter()方法,所以方法内直接调用本类的两个name,money变量,因此结果2返回的是两个初始值。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。如有错误或未考虑完全的地方,望不吝赐教。

(0)

相关推荐

  • java 利用反射获取内部类静态成员变量的值操作

    昨晚,一同事问到我,怎么利用java反射解析内部类静态成员变量的值,于是顺手写下了. 废话不多说,直接上代码! 待解析类结构如下: /** * @Author changle * @Time 17/6/13. * @Desc to do */ public class Goods { static class apple{ public static String version = "iphone6s[是手机不是吃的苹果]"; public static String date =

  • Java如何给变量取合适的命名

    一.变量命名风格 变量命名风格通常会根据不同的变量类型来区分,以Java语言为例,根据变量类型不同有两种命名风格: 1)类成员变量.局部变量 类成员变量.局部变量通常采用驼峰命名风格,如下: String userName; 2)静态成员变量.枚举值.常量 静态成员变量.枚举值.常量通常采用所有字母大写.多个单词以英文下划线连接,如: public static final int MAX_YEARS = 25; ​ // 建议枚举类都以Enum结尾 enum ColorEnum { RED(0

  • Java tomcat环境变量及idea配置解析

    一.下载Tomcat 1.进入官网http://tomcat.apache.org/,选择download,下载所需Tomcat版本. 二,我们解压后到指定目录,然后配置环境变量 1>CATALINA_BASE和CATALINA_HOME,值都是tomact地址目录 2>CLASSPATH,在值后面添加;%CATALINA_HOME%\lib\servlet-api.jar;(PS::这个符号是有的) 3>添加Path值,%CATALINA_HOME%\bin和%CATALINA_HOM

  • Win10系统下配置java环境变量的全过程

    一,配置环境变量步骤 1.右击桌面上的"此电脑"图标,选择属性. 2.选择高级系统设置 3.单击环境变量 4.单击系统变量中的新建 5.在变量名中输入JAVA_HOME 变量值中输入jdk安装路径,系统默认路径为 C:\Program Files\Java\jdk1.8.0_221 6.继续单击系统变量中的新建 7.在变量名中输入CLASSPATH 变量值为 .;%JAVA_HOME%lib;%JAVA_HOME%\lib\tools.jar 注意最前面的"."不能

  • 解决java中的父类私有成员变量的继承问题

    如果父类中属性为私有(private),那么能否被子类继承呢? 答案是不可以. 我们看如下简单代码 class Father { private String name; public void sayHi() { System.out.println("My name is " + this.name); } } class Son extends Father {} public class PrivateFieldTest { public static void main(St

  • java创建子类对象设置并调用父类的变量操作

    通过子类调用父类的变量,有两种方法: 1.把父类的变量设置成public: package triangle.opengl.wlz.stu.childusefathervariable; import android.util.Log; public class BasePublicVariable { private String TAG = getClass().getName(); public int data; public void ptData(){ Log.d(TAG, "ptD

  • Java子类实例化总是默认调用父类的无参构造操作

    子类实例化时,默认调用父类的无参构造方法(不管子类的构造器有没有参数,因为子类继承的是父类的属性和方法,只调用父类的无参构造器就可以继承父类的属性和方法,因此不会调用父类的有参构造器),再调用子类的有参/无参构造器. 示例: package classTest; class Father { public Father(){ System.out.println("父类的无参构造方法"); } public Father(int a ) { System.err.println(&qu

  • Java创建内部类对象实例详解

    Java创建内部类对象实例详解 要想使用new生成一个内部类的实例,需要先指向一个外部类的实例,也就是先生成外部类的实例, 因为内部类可以调用外部类的成员,当没有外部类实例的时候也就没有这些成员的内存空间,内部类在实例化的时候,调用外部类的成员就会出错,所以需要使用外部类的实例 + 点 + new 的方式实例化一个新的内部类 class TestInner{ public static void main(String [] args) { Outer outer = new Outer();

  • Java 判断实体对象及所有属性是否为空的操作

    1.判断实体对象是否为空 2.判断对象所有属性是否为空 3.特别注意,实体类中如果有基本数据类型,会影响判断 package com.liuxd.object; import org.apache.commons.lang3.StringUtils; import java.lang.reflect.Field; /** * Created by Liuxd on 2018/11/2. */ public class TestEntity { public static void main(St

  • Java创建二叉搜索树,实现搜索,插入,删除的操作实例

    Java实现的二叉搜索树,并实现对该树的搜索,插入,删除操作(合并删除,复制删除) 首先我们要有一个编码的思路,大致如下: 1.查找:根据二叉搜索树的数据特点,我们可以根据节点的值得比较来实现查找,查找值大于当前节点时向右走,反之向左走! 2.插入:我们应该知道,插入的全部都是叶子节点,所以我们就需要找到要进行插入的叶子节点的位置,插入的思路与查找的思路一致. 3.删除: 1)合并删除:一般来说会遇到以下几种情况,被删节点有左子树没右子树,此时要让当前节点的父节点指向当前节点的左子树:当被删节点

  • C++/JAVA/C#子类调用父类函数情况总结

    时间久了就容易记不清了,特留存备用查看 c++ 1.构造函数调用   常用初始化列表  或者显示调用 1.1同一个类中构造函数调用构造函数   尽量不要这样做,因为结果不确定!避免麻烦 可以把共用的代码封装成一个私有的成员函数,然后在构造函数内统一调用. 1.2子类构造函数调用基类构造函数 -----基类有默认构造函数时,可以在子类不写,则隐式调用 -----基类无/有默认构造函数时,在子类构造函数初始化列表处调用,则显示调用     基类类名(参数) class Base { public:

  • Java super关键字调用父类过程解析

    这篇文章主要介绍了Java super关键字调用父类过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 话不多说,直接上代码: package com.my.pac14; /** * @auther Summerday */ public class SuperTest { public static void main(String[] args) { SubClass sb = new SubClass(20); //创建子类的对象,调

  • java中子类继承父类,程序运行顺序的深入分析

    我们经常在项目中使用继承,但是往往不太明白,程序运行的顺序以及原理,尤其是使用上转型对象的时候,以及父类子类中都有static变量和方法时,不知道先运行谁.我也是写了一个例子.总结了一下. 复制代码 代码如下: 父类:public class TestStatic { public static String name="china"; {       System.out.println("========方法体========");    } static{  

  • Python实现子类调用父类的初始化实例

    前言 python中进行面向对象编程,当在子类的实例中调用父类的属性时,由于子类的__init__方法重写了父类的__init__方法,如果在子类中这些属性未经过初始化,使用时就会出错. 例如以下的代码: class A(object): def __init__(self): self.a = 5 def function_a(self): print('I am from A, my value is %d' % self.a) class B(A): def __init__(self):

  • 详解 Java继承关系下的构造方法调用

    详解 Java继承关系下的构造方法调用 在Java中创建一个类的对象时,如果该类存在父类,则先调用父类的构造方法,然后再调用子类的构造方法.如果父类没有定义构造方法,则调用编译器自动创建的不带参数的默认构造方法.如果父类定义了public的无参的构造方法,则在调用子类的构造方法前会自动先调用该无参的构造方法.如果父类只有有参的构造方法,没有无参的构造方法,则子类必须在构造方法中必须显式调用super(参数列表)来指定某个有参的构造方法.如果父类定义有无参的构造方法,但无参的构造方法声明为priv

随机推荐