public class Father { private String father; public Father() {
Field fs[] = this.getClass().getDeclaredFields();
for (int i = 0; i < fs.length; i++) {
Field f = fs[i];
System.out.println(f.getType().getName() + " " + f.getName());
}
}}
public class Son extends Father { private int age;
private String name; public Son() {
super();
// TODO Auto-generated constructor stub
}}
public class Test { /**
 * @param args
 */
public static void main(String[] args) {
// TODO Auto-generated method stub
Son son = new Son();
}}这个是打印结果:
int age
java.lang.String name请重点分析Father的构造方法this变量,解释一下打印出来的为什么是上面的结果?我觉得的结果是:
java.lang.String name

解决方案 »

  1.   

    “你觉得”才搞笑,既然Son声明的name应该输出,声明的age为什么就不该输出?this指的是当前的这个实例,main方法里就是一个Son,Son声明了两个成员变量。
      

  2.   

    Field fs[] = this.getClass().getDeclaredFields();         for (int i = 0; i < fs.length; i++) { 
    数组循环输出,结果是对的
      

  3.   

    this.getClass().getDeclaredFields(); 这里的this指的是子类的实例吧,他除了自己的变量还包括父类的变量。你把子类的变量name去掉,结果一样的。
      

  4.   


    不好意思,我说错了
    我觉得的结果这个是,
    java.lang.String fahter
      

  5.   

    楼主肯定是受了父类构造方法的影响。其实不然在类的构造时确实要先调用父类中的构造方法。但是父类的构造方法中用的是this,this代表的是当前对象的实例,而你是new Son自然this就代表Son了打印出Son类的成员变量一点也不奇怪
      

  6.   

    private String father;
    改为
    protected String father;
    输出结果还是:
    int age
    java.lang.String name
    而没有
    java.lang.String father
    何解?
      

  7.   


    恩,这个this指的是当前对象,在运行的时候并不一定是当前类的一个实例。可以这么理解吧?
      

  8.   

    为啥会这样呢,是因为getDeclaredFields()方法造成的
    getDeclaredFields这个方法能获取到这个类本身的所有字段不论是private还是其它的。继承的就不行了。必须要是在本类中声明的。而反射中还提供了一个getFields方法这个方法可以得到继承的但是必须是public修饰的
      

  9.   


    getFields()获得某个类的所有的公共(public)的字段,包括父类。 getDeclaredFields()获得某个类的所有申明的字段,即包括public、private和proteced,
    但是不包括父类的申明字段。 
      

  10.   

    我是看题目才进来的,这明明是子类访问父类的成员变量。
    子类被实例化的时候调用父类的构造方法。
    另外给你一个简历可以看得更直观。你输出一下子类对象的地址,父类对象的地址,然后输出一下this的地址。看看this和哪一个一样。