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

 更新时间:2021年01月13日 10:33:58   作者:hongge372  
这篇文章主要介绍了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返回的是两个初始值。

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

相关文章

  • SpringFactoriesLoader类作用详解

    SpringFactoriesLoader类作用详解

    SpringFactoriesLoader可以加载jar包下META-INF下的spring.factories,把相关接口的实现按照key,value的形式加载到内存,一个接口的多个实现可以按照","进行分割
    2022-10-10
  • Java并发编程中的阻塞队列解析

    Java并发编程中的阻塞队列解析

    这篇文章主要介绍了Java并发编程中的阻塞队列解析,阻塞队列BlockingQueue是一个支持两个附加操作的队列,这两个附加的操作是在队列为空时,获取元素的线程会等待队列变为非空,当队列满时,存储元素的线程会等待队列可用,需要的朋友可以参考下
    2023-08-08
  • Java设计模式七大原则之接口隔离原则详解

    Java设计模式七大原则之接口隔离原则详解

    接口隔离原则(Interface Segregation Principle),又称为ISP原则,就是在一个类中不要定义过多的方法,接口应该尽量简单细化。本文将为大家具体介绍一下Java设计模式七大原则之一的接口隔离原则,需要的可以参考一下
    2022-02-02
  • 浅谈java中的TreeMap 排序与TreeSet 排序

    浅谈java中的TreeMap 排序与TreeSet 排序

    下面小编就为大家带来一篇浅谈java中的TreeMap 排序与TreeSet 排序。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12
  • java jackson 将对象转json时,忽略子对象的某个属性操作

    java jackson 将对象转json时,忽略子对象的某个属性操作

    这篇文章主要介绍了java jackson 将对象转json时,忽略子对象的某个属性操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-10-10
  • Java 泛型总结(二):泛型与数组

    Java 泛型总结(二):泛型与数组

    数组与泛型的关系还是有点复杂的,Java 中不允许直接创建泛型数组。本文分析了其中原因并且总结了一些创建泛型数组的方式。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-03-03
  • 使用 Spring Boot 实现 WebSocket实时通信

    使用 Spring Boot 实现 WebSocket实时通信

    本篇文章主要介绍了使用 Spring Boot 实现 WebSocket实时通信,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-10-10
  • springboot实现打印彩色日志

    springboot实现打印彩色日志

    这篇文章主要介绍了springboot实现打印彩色日志的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • Spring Schedule Task动态改写Cron配置方式

    Spring Schedule Task动态改写Cron配置方式

    这篇文章主要介绍了Spring Schedule Task动态改写Cron配置方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-11-11
  • Java静态工厂方法的实例详解

    Java静态工厂方法的实例详解

    这篇文章主要介绍了 Java静态工厂方法的实例详解的相关资料,希望通过本文大家能掌握java今天工厂方法,需要的朋友可以参考下
    2017-09-09

最新评论