基础越来越差,筒子们一起来看道题,java基础
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());
}
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 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(21)
结果1,调用父类的getI(),取的是父类的i。
嗯,这才是本质
再出一个类似的,请各位先用纸写下
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();
}
}
A have construct
嗯,你只是漏写了第3行的输出,0
崩溃了。。。又错了。。。看来有必要隔一段时间就做一做基础题了。。。
没事,有我陪你一起崩溃
改
更能说明问题,第一个tt方法是调用了Override方法.
嗯,原本的代码里木有,就是为了迷惑人的
改成public int i=1;还是一样 关键不是这句
是1,关键是这句,private int i=1; 外部无法引用。
我也错了
结果是1,但不是属性不继承
1吧,属性不继承
看不懂
对头
分析的很透彻。。。这点也一直是我们初学者的盲点@
有帮助~~
学习了···
子类覆盖父类也可以输出1 super.do()就O了 虚拟机其实加载类就是入栈 怎么定义就怎么输出 有heap stack的概念 你就再也不会错了
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了,因为调用的是子类中的方法。