Java在重載中使用Object的問(wèn)題
在重載中使用Object
JAVA中調(diào)用重載方法都是先匹配同類型參數(shù)的方法,如沒(méi)有才會(huì)向上轉(zhuǎn)型去匹配參數(shù)。
例:
public void remove(int i) {
?? ?...
}
public void remove(Object object) {
?? ?...
}?? ?int i = 0; ?? ?Integer it = 0; ?? ?remove(i); //調(diào)用了 remove(int i) 方法 ?? ?remove(it); //調(diào)用了 remove(Object object) 方法
在開發(fā)中遇到了兩個(gè)方法
public boolean lSet(List<Object> value) {
?? ?...
}
public boolean lSet(Object) {
?? ?...
}調(diào)用時(shí):
?? ?List<Integer> list = new ArrayList<>(); ?? ?list.add(1); ?? ?list.add(2); ?? ?lSet(list); ?//調(diào)用了lSet(Object)
調(diào)用了lSet(Object) 而不是lSet(List<Object> value)
不是說(shuō)先匹配類型相同的嗎?
注意重載方法中的參數(shù)List<Object> value List指定了泛型Object,但調(diào)用時(shí)傳入的是List<Integer>此時(shí)并不算同一種類型。
解決辦法
//使用?通配符 或 直接不指定泛型
public boolean lSet(List<?> value) {
?? ?...
}Object的使用:重載equals、hashCode及實(shí)現(xiàn)compareTo
這里主要介紹Java中使用Hashtable、Arrays.sort時(shí)候如果鍵值涉及到對(duì)象、類時(shí)候的處理辦法:
1.重載equals():java中默認(rèn)的對(duì)象的equals是當(dāng)指向同一內(nèi)存地址時(shí)才為true;如果你現(xiàn)在需要利用對(duì)象里面的值來(lái)判斷是否相等,則重載equal方法。
2.重載hashCode():只有當(dāng)類需要放在HashTable、HashMap、HashSet等等hash結(jié)構(gòu)的集合時(shí)才會(huì)重載hashCode,原因:就HashMap來(lái)說(shuō),好比HashMap就是一個(gè)大內(nèi)存塊,里面有很多小內(nèi)存塊,小內(nèi)存塊里面是一系列的對(duì)象,可以利用hashCode來(lái)查找小內(nèi)存塊hashCode%size(小內(nèi)存塊數(shù)量),所以當(dāng)equal相等時(shí),hashCode必須相等,而且如果是object對(duì)象,必須重載hashCode和equal方法。
3.實(shí)現(xiàn)接口Comparable:當(dāng)需要調(diào)用sort()之類的函數(shù)要用到對(duì)象的比較的基本操作時(shí)候,就需要對(duì)Object的compareTo(Object arg0)進(jìn)行實(shí)現(xiàn)。
4.binarySearch使用注意:由于Arrays.binarySearch(Object array[],Object key)中沒(méi)有給定查找數(shù)組的范圍,據(jù)我估計(jì)可能是0到length-1,因而數(shù)組最好是都能填滿對(duì)象,如果部分為空(數(shù)組開的過(guò)大)則會(huì)出錯(cuò)。而且搜索前要調(diào)用sort函數(shù)排序一下。因?yàn)閿?shù)組長(zhǎng)度和對(duì)象個(gè)數(shù)相同,所以sort(Object [])也不用給定范圍而全部排序。
下面是一個(gè)簡(jiǎn)單的例子
public class TermPOS implements Comparable{
? ? public String term;
? ? public String pos;
? ? public TermPOS(String a,String b)
? ? {
? ? ? ? term = a;
? ? ? ? pos = b;
? ? }
? ? //用于調(diào)用Arrays.sort(Object[])時(shí)的自定義大小,此時(shí)類后加上implements Comparable
? ? public int compareTo(Object arg0) {
? ? ? ? // TODO 自動(dòng)生成方法存根
? ? ? ? if(this.term.compareTo(((TermPOS)arg0).term) != 0)
? ? ? ? ? ? return this.term.compareTo(((TermPOS)arg0).term);
? ? ? ? return this.pos.compareTo(((TermPOS)arg0).pos);
? ? }
? ??
? ? //當(dāng)類需要放在HashTable、HashMap、HashSet等等hash結(jié)構(gòu)的集合時(shí)才會(huì)重載hashCode
? ? public int hashCode()
? ? {
? ? ? ? return term.hashCode()*pos.hashCode();
? ? }
? ? //如果你現(xiàn)在需要利用對(duì)象里面的值來(lái)判斷是否相等,則重載equal方法
? ? public boolean equals(Object obj)
? ? {
? ? ? ? if(term.compareTo(((TermPOS)obj).term) != 0)return false;
? ? ? ? if(pos.compareTo(((TermPOS)obj).pos) != 0)return false;
? ? ? ? return true;
? ? }
? ? public static void testHashtable()
? ? {
? ? ? ? Hashtable<TermPOS,Integer> t = new Hashtable<TermPOS,Integer>();
? ? ? ? TermPOS x = new TermPOS("a","b");
? ? ? ? t.put(new TermPOS("a","b"), 2);
? ? ? ? if(t.get(x) == null)System.out.println("wrong!"); //當(dāng)去掉hashCode的重寫后就輸出這個(gè)
? ? ? ? else System.out.println(t.get(x));
? ? ? ? System.out.println(x.equals(new TermPOS("a","b")));
? ? }?
? ? public static void testSort()
? ? {
? ? ? ? TermPOS tp[] = new TermPOS[3];
? ? ? ? tp[0] = new TermPOS("b","c");
? ? ? ? tp[1] = new TermPOS("a","c");
? ? ? ? tp[2] = new TermPOS("a","b");
? ? ? ? Arrays.sort(tp,0,3);
? ? ? ? for(int i = 0;i < 3;i ++)
? ? ? ? ? ? System.out.println(tp[i].term+"\t"+tp[i].pos);
? ? }
? ? /**
? ? ?* @param args
? ? ?* @throws IOException?
? ? ?*/
? ? public static void main(String[] args) throws IOException {
? ? ? ? // TODO 自動(dòng)生成方法存根
? ? ? ? testHashtable();
? ? ? ? testSort();
? ? }
}以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
使用SQL保留兩位小數(shù)的實(shí)現(xiàn)方式
SQL中保留兩位小數(shù)有三種方法:1、使用ROUND()函數(shù)進(jìn)行四舍五入;2、使用CONVERT()函數(shù)和3、CAST()函數(shù)進(jìn)行強(qiáng)制類型轉(zhuǎn)換,這兩種方法會(huì)截?cái)喽嘤嗟奈粩?shù),ROUND()函數(shù)會(huì)保留0位,而CONVERT()和CAST()會(huì)刪除多余的02024-11-11
SpringMVC框架使用jackson封裝數(shù)據(jù)過(guò)程中遇到的問(wèn)題及解決
這篇文章主要介紹了SpringMVC框架使用jackson封裝數(shù)據(jù)過(guò)程中遇到的問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-07-07
Java實(shí)現(xiàn)從數(shù)據(jù)庫(kù)導(dǎo)出大量數(shù)據(jù)記錄并保存到文件的方法
這篇文章主要介紹了Java實(shí)現(xiàn)從數(shù)據(jù)庫(kù)導(dǎo)出大量數(shù)據(jù)記錄并保存到文件的方法,涉及Java針對(duì)數(shù)據(jù)庫(kù)的讀取及文件寫入等操作技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11
uploadify上傳及后臺(tái)文件合法性驗(yàn)證的代碼解析
這篇文章主要介紹了uploadify上傳及后臺(tái)文件合法性驗(yàn)證的代碼解析,整段代碼分為后臺(tái)上傳方法,文件合法性驗(yàn)證類,前端上傳js,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-11-11
ES結(jié)合java代碼聚合查詢?cè)敿?xì)示例
es查詢有一個(gè)很常用的一種叫聚合查詢,相當(dāng)于mysql中的分組group by 后拿各組數(shù)量進(jìn)行統(tǒng)計(jì),實(shí)現(xiàn)起來(lái)也是很簡(jiǎn)單,下面這篇文章主要給大家介紹了關(guān)于ES結(jié)合java代碼聚合查詢的相關(guān)資料,需要的朋友可以參考下2023-05-05

