深入理解java中this关键字的使用

 更新时间:2017年08月14日 12:08:15   作者:美好的明天  
这篇文章主要介绍了this关键字的使用,通过调用构造方法,使用this关键字调用当前对象等详细介绍了this的特点和使用,需要的朋友可以参考下

一,表示类中属性

1,没有使用this的情况

class Person{  // 定义Person类
 private String name ;  // 姓名
 private int age ;   // 年龄
 public Person(String name,int age){ // 通过构造方法赋值
  name = name ;
  age = age ;
 }
 public String getInfo(){ // 取得信息的方法
  return "姓名:" + name + ",年龄:" + age ;
 }
};
public class ThisDemo01{
 public static void main(String args[]){
  Person per1 = new Person("张三",33) ; // 调用构造实例化对象
  System.out.println(per1.getInfo()) ; // 取得信息
 }
};

运行结果:

姓名:null,年龄:0;

可以得出结论:此时并没有正确将内容赋给属性;

假设身边有一只笔,远处也有一只笔,肯定会就近拿身边的笔。这在构造方法中一样。
所以此时操作的name,age都是构造方法中定义的name,age.跟类中属性完全不沾边。
此时,为了明确哪个是类中的属性,需要加上this.类中属性。

class Person{  // 定义Person类
 private String name ;  // 姓名
 private int age ;   // 年龄
 public Person(String name,int age){ // 通过构造方法赋值
  this.name = name ; // 为类中的name属性赋值
  this.age = age ;// 为类中的age属性赋值
 }
 public String getInfo(){ // 取得信息的方法
  return "姓名:" + name + ",年龄:" + age ;
 }
};
public class ThisDemo02{
 public static void main(String args[]){
  Person per1 = new Person("张三",33) ; // 调用构造实例化对象
  System.out.println(per1.getInfo()) ; // 取得信息
 }
};

运行结果:

姓名:张三,年龄:33

二,this调用构造方法

如果在类中有多个构造方法,也可以利用this关键字互相调用。
假设一个类中存在多个构造方法,但无论多少构造方法,都要打造一个“新对象实例化”,此时就有两种做法。

按照最原始方法:

class Person{  // 定义Person类
 private String name ;  // 姓名
 private int age ;   // 年龄
 public Person(){ // 无参构造
  System.out.println("新对象实例化") ;
 }
 public Person(String name){
  System.out.println("新对象实例化") ;
  this.name = name ;
 }
 public Person(String name,int age){ // 通过构造方法赋值
  System.out.println("新对象实例化") ;
  this.name = name ; // 为类中的name属性赋值
  this.age = age ;// 为类中的age属性赋值
 }
 public String getInfo(){ // 取得信息的方法
  return "姓名:" + name + ",年龄:" + age ;
 }
};
public class ThisDemo03{
 public static void main(String args[]){
  Person per1 = new Person("张三",33) ; // 调用构造实例化对象
  System.out.println(per1.getInfo()) ; // 取得信息
 }
};

因为以上红色部分重复了,现在只是一行,感觉不出来,但是如果现在代码很多行的话,缺陷立刻显现出来了。

此时,最好让构造方法间进行互相调用。

使用:this(若干参数)的形式完成。

package methoud;
class Person{  // 定义Person类
 private String name ;  // 姓名
 private int age ;   // 年龄
 public Person(){ // 无参构造  
  System.out.println("新对象实例化") ;
 }
 public Person(String name){
  this() ;// 调用本类中的无参构造方法
  this.name = name ;
 }
 public Person(String name,int age){ // 通过构造方法赋值
  this(name) ;// 调用有一个参数的构造方法
  this.age = age ;// 为类中的age属性赋值
 }
 public String getInfo(){ // 取得信息的方法
  return "姓名:" + name + ",年龄:" + age ;
 }
};
public class ThisDemo06{
 public static void main(String args[]){
  Person per1 = new Person("张三",33) ; // 调用构造实例化对象
  System.out.println(per1.getInfo()) ; // 取得信息
 }
};

运行结果:

新对象实例化
姓名:张三,年龄:33

注意点:

在使用this关键字调用其他关键字的时候,有以下限制:

1)this()调用其他构造方法的语句只能放在构造方法(在其他普通方法里是不行的)的首行;

2)在使用this调用其他构造方法的时候,至少有一个构造方法是不用this调用的。(必须要有结尾,不能无限期的调用下去,循环递归调用);

如下就会出错:

package methoud;
class Person{  // 定义Person类
 private String name ;  // 姓名
 private int age ;   // 年龄
 public Person(){ // 无参构造
  System.out.println("新对象实例化") ;
 }
 public Person(String name){
  this.name = name ;
  this() ;// 调用this()方法只能放在构造方法首行
 }
 public Person(String name,int age){ // 通过构造方法赋值
  this(name) ;// 调用有一个参数的构造方法
  this.age = age ;// 为类中的age属性赋值
 }
 public String getInfo(){ // 取得信息的方法
  this() ;// 其他普通方法不能调用this()方法
  return "姓名:" + name + ",年龄:" + age ;
 }
};
public class ThisDemo04{
 public static void main(String args[]){
  Person per1 = new Person("张三",33) ; // 调用构造实例化对象
  System.out.println(per1.getInfo()) ; // 取得信息
 }
};

三,使用this关键字调用当前对象。

当前对象:当前正在调用方法的对象。

如下,分别用两种方法打印对象per1和per2

class Person{  // 定义Person类
 public String getInfo(){ // 取得信息的方法
  System.out.println("Person类 --> " + this) ; // 直接打印this
  return null ; // 为了保证语法正确,返回null
 }
};
public class ThisDemo06{
 public static void main(String args[]){
  Person per1 = new Person() ; // 调用构造实例化对象
  Person per2 = new Person() ; // 调用构造实例化对象
  System.out.println("MAIN方法 --> " + per1) ; // 直接打印对象
  per1.getInfo() ; // 当前调用getInfo()方法的对象是per1
  System.out.println("MAIN方法 --> " + per2) ; // 直接打印对象
  per2.getInfo() ; // 当前调用getInfo()方法的对象是per2
 }
};

运行结果:

MAIN方法 --> methoud.Person@2a139a55
Person类 --> methoud.Person@2a139a55
MAIN方法 --> methoud.Person@15db9742
Person类 --> methoud.Person@15db9742

可见,用this调用的是当前对象,与直接per1,per2是一样的效果。

四,对象的比较

以下这个例子中,生成两个对象,当对象中年龄和姓名完全相等的时候,则认为两个对象是相等的,此时有两个问题

1)如何进行对象比较:

2)在那块对象比较:

String本身是一个类,如果要进行相等比较,需要使用equls(),而,age是Int,直接使用==判断。

class Person{  // 定义Person类
 private String name ; // 姓名
 private int age ;  // 年龄
 public Person(String name,int age){
  this.setName(name) ;
  this.setAge(age) ;
 }
 public void setName(String name){ // 设置姓名
  this.name = name ;
 }
 public void setAge(int age){  // 设置年龄
  this.age = age ;
 }
 public String getName(){
  return this.name ;
 }
 public int getAge(){
  return this.age ;
 }
};
public class ThisDemo07{
 public static void main(String args[]){
  Person per1 = new Person("张三",30) ; // 声明两个对象,内容完全相等
  Person per2 = new Person("张三",30) ; // 声明两个对象,内容完全相等
  // 直接在主方法中依次取得各个属性进行比较
  if(per1.getName().equals(per2.getName())&&per1.getAge()==per2.getAge()){
   System.out.println("两个对象相等!") ;
  }else{
   System.out.println("两个对象不相等!") ;
  }
 }
};

运行结果:

两个对象相等!

以上代码,功能确实实现了,但是由于代码暴露在外面,不安全,容易出错。
应该由自己进行比较最合适,所以应该在Person类中增加一个比较的方法。
当前对象调用传人的对象,当前对象即调用方法的对象,用this表示,
这里表示在哪里比较。

如下:

class Person{  // 定义Person类
 private String name ; // 姓名
 private int age ;  // 年龄
 public Person(String name,int age){
  this.setName(name) ;
  this.setAge(age) ;
 }
 public boolean compare(Person per){
  // 调用此方法时里面存在两个对象:当前对象、传入的对象
   Person p1 = this ; // 当前的对象,就表示per1
  Person p2 = per ; // 传递进来的对象,就表示per2
  if(p1==p2){ // 判断是不是同一个对象,用地址比较
   return true ;
  }
  // 之后分别判断每一个属性是否相等
  if(p1.name.equals(p2.name)&&p1.age==p2.age){
   return true ; // 两个对象相等
  }else{
   return false ; // 两个对象不相等
  }
 }
 public void setName(String name){ // 设置姓名
  this.name = name ;
 }
 public void setAge(int age){  // 设置年龄
  this.age = age ;
 }
 public String getName(){
  return this.name ;
 }
 public int getAge(){
  return this.age ;
 }
};
public class ThisDemo08{
 public static void main(String args[]){
  Person per1 = new Person("张三",30) ; // 声明两个对象,内容完全相等
  Person per2 = new Person("张三",30) ; // 声明两个对象,内容完全相等
  // 直接在主方法中依次取得各个属性进行比较
  if(per1.compare(per2)){
   System.out.println("两个对象相等!") ;
  }else{
   System.out.println("两个对象不相等!") ;
  }
 }
};

运行结果:

两个对象相等!

以上就是小编整理的全部内容啦,希望大家继续支持脚本之家~

相关文章

  • Java打乱ArrayList生成一个随机序列列表

    Java打乱ArrayList生成一个随机序列列表

    有时候会需要将一个ArrayList或者数组中的数字打乱,方便后续使用,比如随机出题、答案选项打乱、连线题打乱、抽奖号码打乱等等,把我自己写的一段代码贴出来分享给大家。
    2016-08-08
  • java结束进程的实例代码

    java结束进程的实例代码

    java结束程序进程的方法很简单,只要一句代码就行,大家参考使用吧
    2013-12-12
  • IntelliJ IDEA 2019.2 x64的安装、应用与简单配置(图文)

    IntelliJ IDEA 2019.2 x64的安装、应用与简单配置(图文)

    这篇文章主要介绍了IntelliJ IDEA 2019.2 x64的安装、应用与简单配置,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • JVM虚拟机性能监控与故障处理工具介绍

    JVM虚拟机性能监控与故障处理工具介绍

    这篇文章主要为大家介绍了JVM虚拟机性能监控与故障处理工具介绍,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-07-07
  • 关于@Scheduled参数及cron表达式解释

    关于@Scheduled参数及cron表达式解释

    这篇文章主要介绍了关于@Scheduled参数及cron表达式解释,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • Spring Security6 最新版配置及实现动态权限管理

    Spring Security6 最新版配置及实现动态权限管理

    Spring Security 在最近几个版本中配置的写法都有一些变化,很多常见的方法都废弃了,并且将在未来的 Spring Security7 中移除,因此又补充了一些新的内容,重新发一下,供各位使用 Spring Security 的小伙伴们参考,需要的朋友可以参考下
    2024-03-03
  • SpringBoot中使用Swagger的最全方法详解

    SpringBoot中使用Swagger的最全方法详解

    Swagger是一个规范和完整的框架,用于生成、描述、调用和可视化Restful风格的Web服务,这篇文章主要给大家介绍了关于SpringBoot中使用Swagger的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2023-12-12
  • mybatis初始化SqlSessionFactory失败的几个原因分析

    mybatis初始化SqlSessionFactory失败的几个原因分析

    这篇文章主要介绍了mybatis初始化SqlSessionFactory失败的几个原因分析,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • Spring Cloud 专题之Sleuth 服务跟踪实现方法

    Spring Cloud 专题之Sleuth 服务跟踪实现方法

    这篇文章主要介绍了Spring Cloud 专题之Sleuth 服务跟踪,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-08-08
  • SpringMVC @RequestBody Date类型的Json转换方式

    SpringMVC @RequestBody Date类型的Json转换方式

    这篇文章主要介绍了SpringMVC @RequestBody Date类型的Json转换方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-10-10

最新评论