Java this关键字详解
this 关键字用来表示当前对象本身,或当前类的一个实例,通过 this 可以调用本对象的所有方法和属性。例如:
运行结果:
x + y = 25
上面的程序中,obj 是 Demo 类的一个实例,this 与 obj 等价,执行 int z = this.x + this.y;,就相当于执行 int z = obj.x + obj.y;。
注意:this 只有在类实例化后才有意义。
运行结果:
网站的名字是微学苑,已经成立了3年
形参的作用域是整个方法体,是局部变量。在Demo()中,形参和成员变量重名,如果不使用this,访问到的就是局部变量name和age,而不是成员变量。在 say() 中,我们没有使用 this,因为成员变量的作用域是整个实例,当然也可以加上 this:
Java 默认将所有成员变量和成员方法与 this 关联在一起,因此使用 this 在某些情况下是多余的。
运行结果:
网站的名字是微学苑,已经成立了3年
值得注意的是:
上述代码涉及到方法重载,即Java允许出现多个同名方法,只要参数不同就可以。后续章节会讲解。
运行结果:
Hello from A!
Hello from B!
匿名对象就是没有名字的对象。如果对象只使用一次,就可以作为匿名对象,代码中 new B(this).print(); 等价于 ( new B(this) ).print();,先通过 new B(this) 创建一个没有名字的对象,再调用它的方法。
- public class Demo{
- public int x = 10;
- public int y = 15;
- public void sum(){
- // 通过 this 点取成员变量
- int z = this.x + this.y;
- System.out.println("x + y = " + z);
- }
- public static void main(String[] args) {
- Demo obj = new Demo();
- obj.sum();
- }
- }
x + y = 25
上面的程序中,obj 是 Demo 类的一个实例,this 与 obj 等价,执行 int z = this.x + this.y;,就相当于执行 int z = obj.x + obj.y;。
注意:this 只有在类实例化后才有意义。
使用this区分同名变量
成员变量与方法内部的变量重名时,希望在方法内部调用成员变量,怎么办呢?这时候只能使用this,例如:- public class Demo{
- public String name;
- public int age;
- public Demo(String name, int age){
- this.name = name;
- this.age = age;
- }
- public void say(){
- System.out.println("网站的名字是" + name + ",已经成立了" + age + "年");
- }
- public static void main(String[] args) {
- Demo obj = new Demo("微学苑", 3);
- obj.say();
- }
- }
网站的名字是微学苑,已经成立了3年
形参的作用域是整个方法体,是局部变量。在Demo()中,形参和成员变量重名,如果不使用this,访问到的就是局部变量name和age,而不是成员变量。在 say() 中,我们没有使用 this,因为成员变量的作用域是整个实例,当然也可以加上 this:
- public void say(){
- System.out.println("网站的名字是" + this.name + ",已经成立了" + this.age + "年");
- }
作为方法名来初始化对象
也就是相当于调用本类的其它构造方法,它必须作为构造方法的第一句。示例如下:- public class Demo{
- public String name;
- public int age;
- public Demo(){
- this("微学苑", 3);
- }
- public Demo(String name, int age){
- this.name = name;
- this.age = age;
- }
- public void say(){
- System.out.println("网站的名字是" + name + ",已经成立了" + age + "年");
- }
- public static void main(String[] args) {
- Demo obj = new Demo();
- obj.say();
- }
- }
网站的名字是微学苑,已经成立了3年
值得注意的是:
- 在构造方法中调用另一个构造方法,调用动作必须置于最起始的位置。
- 不能在构造方法以外的任何方法内调用构造方法。
- 在一个构造方法内只能调用一个构造方法。
上述代码涉及到方法重载,即Java允许出现多个同名方法,只要参数不同就可以。后续章节会讲解。
作为参数传递
需要在某些完全分离的类中调用一个方法,并将当前对象的一个引用作为参数传递时。例如:- public class Demo{
- public static void main(String[] args){
- B b = new B(new A());
- }
- }
- class A{
- public A(){
- new B(this).print(); // 匿名对象
- }
- public void print(){
- System.out.println("Hello from A!");
- }
- }
- class B{
- A a;
- public B(A a){
- this.a = a;
- }
- public void print() {
- a.print();
- System.out.println("Hello from B!");
- }
- }
Hello from A!
Hello from B!
匿名对象就是没有名字的对象。如果对象只使用一次,就可以作为匿名对象,代码中 new B(this).print(); 等价于 ( new B(this) ).print();,先通过 new B(this) 创建一个没有名字的对象,再调用它的方法。
<上一节下一节>
被顶起来的评论
package thisfangfa;
public class This {
public static void main(String[] args){
B b=new B(new A());//这里创建B类的对象b时,对B类的构造函数传入了
//A类的对象的引用(指针),
}
}
class A{
public A()
{
System.out.println www.uuweb.cn ("step 1 ");
new B(this).print();//程序第一步会执行A类的构造方法A(),因为创建B类
//的对象b时,对B类的构造函数传入了A类的对象的引用(指针),所以程序先执行
//new A() ,执行new A()的时候就运行了A类的构造方法。A类的构造方法里面
//创建了B类的匿名对象,并且引用了B类匿名对象的print();方法。
}
public void print()
{
System.out.println("step 3");//由于第二步a.print();执行了A类的
//print()方法。所以程序第三步会运行到这里。
System.out.println("hello from A");//然后执行到这句
//代码,所以打印输出了hello from A
}
}
class B{
A a;//这里先声明一个A类的对象a,这时还没有对a实例化,只是声明。
public B(A a){//执行new A()完毕后,开始执行执行new B()了,这时会执行B类的
//构造函数B(),
this.a=a;//B b=new B(new A());//这里创建B类的对象b时,传入的A类对象
//的引用(指针),赋予了之前声明的A类的对象a,这时a存储着创建B类的对象b时,传
//入的A类对象的引用(指针)。
}
public void print()
{ System.out.println("step 2 ");//由于引用了B类匿名对象的print()方法。
//所以程序第二步会执行到这个方法里面。
a.print();//因为a存储着创建B类的对象b时,传入的A类对象的引用(指针)。
//所以这里执行a对象的方法print(),就是执行的A这个类里面的
//print()方法。所以程序第二步会运行到这里。这里执行了A类的print()方法。
//
//打印输出hello from A完毕后,a.print();执行完毕,
System.out.println("step 4 ");//所以开始执行这句
System.out.println("hello from B");//和执行这句
//整个程序结束在这里。
}
}
在Eclipse下程序输出结果是这样的:
step 1
step 2
step 3
hello from A
step 4
hello from B