泛型 - void *
由于集合中什么類型的元素都可以存儲谜诫,導(dǎo)致取出時厌丑,如果出現(xiàn)強轉(zhuǎn)就會發(fā)生ClassCastException異常兰迫,為了解決這個問題淀零,使用集合時漾唉,必須明確指出集合中元素的類型荧库,這種方式稱為:泛型。
泛型的本質(zhì)是參數(shù)化類型赵刑,也就是說所操作的數(shù)據(jù)類型被指定為一個參數(shù)分衫。
- 泛型方法
所有泛型方法聲明都有一個類型參數(shù)聲明部分(由尖括號分隔),該類型參數(shù)聲明部分在方法返回類型之前般此。
每一個類型參數(shù)聲明部分包含一個或多個類型參數(shù)蚪战,參數(shù)間用逗號隔開。一個泛型參數(shù)铐懊,也被稱為一個類型變量邀桑,是用于指定一個泛型類型名稱的標(biāo)識符。
類型參數(shù)能被用來聲明返回值類型科乎,并且能作為泛型方法得到的實際參數(shù)類型的占位符壁畸。
泛型方法體的聲明和其他方法一樣。注意類型參數(shù)只能代表引用型類型,不能是原始類型(像int,double,char的等)捏萍。 - 泛型類
泛型類的聲明和非泛型類的聲明類似太抓,除了在類名后面添加了類型參數(shù)聲明部分。
和泛型方法一樣令杈,泛型類的類型參數(shù)聲明部分也包含一個或多個類型參數(shù)走敌,參數(shù)間用逗號隔開。一個泛型參數(shù)逗噩,也被稱為一個類型變量掉丽,是用于指定一個泛型類型名稱的標(biāo)識符。因為他們接受一個或多個參數(shù)给赞,這些類被稱為參數(shù)化的類或參數(shù)化的類型机打。 - 泛型數(shù)組
1.集合里面對象不能重復(fù) 若重復(fù) 不會提示錯誤 但添加不進(jìn)去
- 內(nèi)部使用HashMap來實現(xiàn) 鍵值對 鍵key不能重復(fù)
- "jack":obj
2.集合是無序的 添加的順序和存儲的順序無關(guān)
- 使用默認(rèn)排序
- 哈希算法
- 如何實現(xiàn)HashMap里面key不同
- 計算這個key對應(yīng)的對象的hashi值
- 整數(shù):在對象的地址的基礎(chǔ)上按照一定算法計算出來的一個整數(shù)
- 如果倆個對象相同 name計算出來的hash值相同
equals 比較的是對象內(nèi)部的內(nèi)容
使用的兩個對象必須實現(xiàn)Comparable接口的compareTo方法
conpareTo里面實現(xiàn)具體該如何比較
HashMap 集合 存儲數(shù)據(jù)的特點:鍵key - 值value
key不能重復(fù) 可以是任意的對象類型 通常使用字符串String
技術(shù)的使用
可以排序的集合
TreeSet<Person> score = new TreeSet<>(new Comparator<Person>() {
@Override
public int compare(Person person, Person t1) {
return person.compareTo(t1);
}
});
TreeSet<Person> score = new TreeSet<>((Person p1,Person p2) -> p1.compareTo(p2));
Person p1 = new Person("jack",20);
Person p2 = new Person("jack",30);
Person p3 = new Person("Alice",15);
score.add(p1);
score.add(p2);
score.add(p3);
添加對象:鍵值對
score.put("Chinese",89);
score.put("Math",94);
score.put("English",92);
更改某個鍵對應(yīng)的值
score.put("Chinese",91);
獲取鍵值對的個數(shù)
score.size();
獲取所有的key
System.out.println(score.keySet());
獲取所有的value
System.out.println(score.values());
獲得Entry
System.out.println(score.entrySet());
獲取一個鍵key對應(yīng)的值
System.out.println(score.get("English"));
鍵值對的遍歷
//1.通過遍歷key來得到每一個key對應(yīng)的值
for(String key:score.keySet()){
//通過key得到值
int s = score.get(key);
System.out.println("key"+key+"value:"+s);
}
System.out.println("-------------");
//2.通過entrySet 得到Entry對象的集合
//一個Entry管理一個鍵值對 getKey getValue
Set<Map.Entry<String,Integer>> entrys = score.entrySet();
for(Map.Entry entry: entrys){
//得到Entry對應(yīng)的key
String key = (String)entry.getKey();
//獲取Entry對應(yīng)的值
Integer value = (Integer)entry.getValue();
System.out.println("key"+key+"value:"+value);
}
泛型
class GenericTest<E>{
E a1;
E a2;
public void test(E a1,E a2){
this.a1 = a1;
this.a2 = a2;
System.out.println(a1.equals(a2));
}
}
異常處理
處理運行過程能中出現(xiàn)的不可控的錯誤:error 使程序更健壯
異常發(fā)生的原因有很多,通常包含以下幾大類:
- 用戶輸入了非法數(shù)據(jù)片迅。
- 要打開的文件不存在残邀。
- 網(wǎng)絡(luò)通信時連接中斷,或者JVM內(nèi)存溢出柑蛇。
這些異常有的是因為用戶錯誤引起芥挣,有的是程序錯誤引起的,還有其它一些是因為物理錯誤引起的耻台。
有以下三種類型的異常:
- 檢查性異常:最具代表的檢查性異常是用戶錯誤或問題引起的異常空免,這是程序員無法預(yù)見的。例如要打開一個不存在文件時盆耽,一個異常就發(fā)生了蹋砚,這些異常在編譯時不能被簡單地忽略。
- 運行時異常: 運行時異常是可能被程序員避免的異常摄杂。與檢查性異常相反坝咐,運行時異常可以在編譯時被忽略析恢。
- 錯誤: 錯誤不是異常墨坚,而是脫離程序員控制的問題。錯誤在代碼中通常被忽略映挂。例如泽篮,當(dāng)棧溢出時,一個錯誤就發(fā)生了柑船,它們在編譯也檢查不到的帽撑。
Exception -
try{
執(zhí)行的代碼
可能會出現(xiàn)異常
一旦出現(xiàn)異常 系統(tǒng)自動為我們創(chuàng)建一個異常類并拋出
}catch(NullPointerException e){
如果需要自己處理異常就catch
}catch(IOEception e){
如果有多個異常 可以用多個catch來捕獲
如果有多個異常 catch的順序是從小到大
}catch(Exception e){
}
finally{
不管有誤異常finally都會被執(zhí)行
處理資源回收 網(wǎng)絡(luò)連接 數(shù)據(jù)庫連接 I/O流
}
如果異常出現(xiàn) 后面的代碼將不會被執(zhí)行
try代碼塊 不要抓太多
使用throws拋出異常 給外部處理
當(dāng)特殊情況出現(xiàn)了 自己可以選擇拋出異常
throws throw new IllegalAccessException();
自定義異常類