在本文的开头,非常感谢Thining in JAVA这本书给我的启发,大师就是大师,正是因为有了你们这些大师对基础的极致追求,我们这些菜鸟才少走了很多弯路,BY THE WAY:
陈昊鹏翻译的那个有点撒?希望我有一天能翻译这本书!!!嘻嘻^-^
this的常见用法:1.在构造器中,显示写出this.成员,区分成员变量与局部变量;
2.在构造器中,用this(实参列表),调用其他的一个构造器,相信大家都懂,不惹人烦啦^-^
this的深入:1.在每一个非静态方法的内部,都有一个this,相当于一个句柄,由编译器隐示添加。method(参数列表)可以看成是method(类名 this,参数列表),在面向对象中,成员属性必须由对象调用,所以在方法内部,每一个成员其实都有一个this.”前缀,当对象调用这个方法的时候,编译器会把该对象传递给方法(也就是常说的“this指向调用该方法的当前对象”),编译器会将其编译为method(对象,实参列表)。
2.在一个静态方法内部,由于静态方法是属于类的,被每个类的实例所共享,所以没有this句柄,当然就不能在静态方法中访问非静态的成员(属性和方法),而具体在编译器会怎么看愣,编译器会说哪个对象调用了成员,他妈的我都找不到这个对象,然后它就会大吼一句“还有谁!!!”,最后报错。
静态方法中不能调用非静态成员的解释:在前期我也曾为找这个问题的原因看了很多的贴,发现解释都经不起推敲,比如说生命周期的不同,甚至有的还扯到了内存。我不知道为什么他们会扯到内存,因为那个报错是编译器给我们报的,不是JAVA虚拟机启动后给我们报的,编译时根本不会扯到内存,因为JAVA程序的OS都还没启动愣,怎么分配内存?其实原因就是上面讲到的this。
很容易验证:
public class Test {
private int i=2;
public void show(){
System.out.println(i);//编译器没有报错
System.out.println(this.i);//编译器没有报错
System.out.println(new Test().i);//编译器没有报错
}
public static void invoke(){
//System.out.println(i);//报错:Cannot make a static reference to the non-static field i
//show();//报错:Cannot make a static reference to
//the non-static method show() from the type Test
//this.show();//报错:Cannot use this in a static context,因为是类成员,没有this句柄
new Test().show();//OK,指定对象,符合面向对象的思想,即非静态成员从属于某个对象(这个用生命周期就解释不通)。
}
}