Java面試:用set集合的時候,重寫過hashcode()和equal()方法嗎?有什么作用?


首先Set接口的特點:

  • 1.它不允許出現重復元素-----------無重復
  • 2.不保證集合中元素的順序---------無序
  • 3.允許包含值為null的元素,但最多只能有一個null元素。

HashSet集合,采用哈希表結構存儲數據,保證元素唯一性的方式依賴於:hashCode()與equals()方法。

1)HashSet集合排重時,需要判斷兩個對象是否相同,對象相同的判斷可以通過hashCode值判斷,所以需要重寫hashCode()方法
2)hashset不能為一樣的,放入一個值首先判斷hashcode(類似下標)是否已經存在,然后用equals判斷是否有一樣的值。
3)如果只重寫其中一個方法的時候,向HashSet集合中添加多個對象時,所有屬性都相同時,並沒有完成想要的排重效果。hashset不能為一樣的,放入一個值首先判斷hashcode(內存中的位置)是否已經存在,然后用equals判斷是否有一樣的值。

情況一:當我們往HashSet集合中添加 8大基本類型和String類型的時候,不需要重寫hashCode()和equals()方法。因為任何對象都是Object類的子類,所以任何對象都擁有這個方法。
情況二:當我們往HashSet集合添加自定義對象的時候,就需要重寫hashCode()和equals()方法。建立自己的比較方式,才能保證HashSet集合中的對象唯一。
案例:

public class Student {
	 private String name;
 	
 	 public Student(String name) {
 		 super();
 		 this.name = name;
 	 }
	 
	 public Student() {
	 	super();
	 }
	
	 public String getName() {
 	 	return name;
 	 }
	
	 public void setName(String name) {
 	 	this.name = name;
	 }
	
	 @Override
	 public String toString() {
 	 	return "Student [name=" + name + "]";
	 }
	
	 @Override
 	  //重寫equals
	 public boolean equals(Object obj) {
     	  //先判斷傳入的參數對象是否是Student對象,若不是直接返回false
		  if(obj instanceof Student) {
	     	    //若是,強轉成Student對象,並比較屬性的值
		   		Student s = (Student) obj;
	 	  	  	if(this.name.equals(s.name)) {
		           	//若屬性的值相同,則返回true
		 		 	return true;	
	  		    }
		  }       
          return false;
	 }
   	
   	@Override
    public int hashCode(){
       /*hashCode方法返回值是int類型,所以重寫時需要找到int類型的數據返回,還要保證此方法的返回值與對象的所有屬性都相關,所以返回姓名屬性的字符串的長度*/
	  	return this.name.length();
   	 }
}


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM