基础越来越差,筒子们一起来看道题,java基础

发布于 2021-11-10 09:15:05 字数 710 浏览 940 评论 21

class A {
    private int i=1;
    public int getI(){
        return i;
    }
    public void setI(int i){
        this.i=i;
    }
}

public class B extends A {
    int i=2;
    public static void main (String [] args) {
        B b = new B();
        System.out.println(b.getI());
    }

}

又是一个N年前我就让在笔记里的题,我又错了

值得反思

 

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(21

梅窗月明清似水 2021-11-16 19:53:31

结果1,调用父类的getI(),取的是父类的i。

残花月 2021-11-16 19:53:31

嗯,这才是本质

酷到爆炸 2021-11-16 19:53:31

再出一个类似的,请各位先用纸写下

class A {
    public int m = 1;

    A() {
        System.out.println("A have construct");
        System.out.println(m);
        tt();
    }

    public void tt() {
        System.out.println(m);
    }
}

public class B extends A {
    public int n = 2;

    B() {
        System.out.println("B have construct");
        System.out.println(n);
        tt();
    }

    public void tt() {
        System.out.println(n);
    }

    public static void main(String args[]) {
        B b = new B();
    }
}

半世蒼涼 2021-11-16 19:53:31

A have construct

醉生梦死 2021-11-16 19:53:31

嗯,你只是漏写了第3行的输出,0

飘然心甜 2021-11-16 19:53:31

崩溃了。。。又错了。。。看来有必要隔一段时间就做一做基础题了。。。

恋你朝朝暮暮 2021-11-16 19:53:31

没事,有我陪你一起崩溃

晚风撩人 2021-11-16 19:53:31

B() {
        System.out.println("B have construct");
        System.out.println(n);
        tt();
        super.tt();
    }

更能说明问题,第一个tt方法是调用了Override方法.

琴流音 2021-11-16 19:53:31

嗯,原本的代码里木有,就是为了迷惑人的

岁月打碎记忆 2021-11-16 19:53:29

改成public int i=1;还是一样 关键不是这句

流心雨 2021-11-16 19:53:19

是1,关键是这句,private int i=1;  外部无法引用。

拥有 2021-11-16 19:53:03

我也错了

想挽留 2021-11-16 19:52:27

结果是1,但不是属性不继承

笑红尘 2021-11-16 19:52:09

1吧,属性不继承

一人独醉 2021-11-16 19:49:49

对头

做个少女永远怀春 2021-11-16 19:46:00

分析的很透彻。。。这点也一直是我们初学者的盲点@

别低头,皇冠会掉 2021-11-16 19:45:23

有帮助~~

只为守护你 2021-11-16 18:30:08

学习了···

等风来 2021-11-16 07:33:42

子类覆盖父类也可以输出1 super.do()就O了 虚拟机其实加载类就是入栈 怎么定义就怎么输出 有heap stack的概念 你就再也不会错了

2021-11-16 06:23:56

1.并不是private成员不会被继承.事实上子类可以继承父类的任何变量和方法。private、protected只是访问权限而已。即使i是public的

输出结果也肯定是1.

2.方法可以覆盖,成员变量并没有覆盖一说,也就是子类的i和父类的i是共存在子类体内的。父类对象中有i变量、set get两个方法。子类class中应有i【继承于父类对象】、i【子类对象】两个变量、set get两个方法【继承于父类对象】。

3.java中的原则是调用的是哪个类的方法,那么这个方法访问的就是这个类中的成员。子类中没有覆盖public int getI()这个方法的话,那么子类调用的其实是父类的getI()方法.所以返回的是父类中的i.

所以如果子类覆盖了getI()方法,那么就会输出的是子类中的i了,因为调用的是子类中的方法。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文