package?imoocCollection;
import?java.util.HashMap;
import?java.util.Map;
import?java.util.Scanner;
import?java.util.Set;
public?class?MapTest?{
//建一個map類型的屬性,用來承裝student對象的
public?Map<String,?Student>?students;
//在構造方法上給students初始化
public?MapTest()?{
this.students?=?new?HashMap<String,?Student>();
}
//測試添加方法:輸入學生的ID,判斷是否被占用
//若未被占用,提示輸入學生姓名,創建新的學生對象,并且添加到students中
//若被占用,打印輸出,該ID已被占用
public?void?testPut()?{
//創建一個Scanner對象
Scanner?sc?=?new?Scanner(System.in);
for(int?i=0;?i<3;?i++)?{
?System.out.println("請輸入學生ID:");
?String?id?=?sc.next();
?//判斷該ID是否被占用
?Student?s?=?students.get(id);
?if(s?==?null)?{
?//提示輸入學生姓名
?System.out.println("請輸入學生姓名:");
?String?name?=?sc.next();
?//創建新的學生對象
?Student?st?=?new?Student(id,?name);
?//通過調用students的put方法添加學生到hash?map里
?students.put(id,?st);
?System.out.println("成功添加學生:"?+?students.get(id).name);
?}
?else?{
?System.out.println("該學生ID已被占用");
?continue;
?}
}
}
//測試map的keySet()方法
public?void?testKeySet()?{
//通過keySet方法返回Map中所有鍵的Set集合
Set<String>?keySet?=?students.keySet();
//取得set的容量
System.out.println("總共有:"?+?keySet.size()?+?"個學生!");
//遍歷keySet,取得每一個鍵,在調用map的get方法取得每個鍵對應的value
for(String?s?:?keySet)?{
Student?st?=?students.get(s);
if(st?!=?null)?{
System.out.println("學生:"?+?st.name);
}
}
}
public?static?void?main(String[]?args)?{
//?TODO?Auto-generated?method?stub
MapTest?mt?=?new?MapTest();
mt.testPut();
mt.testKeySet();
}
}
2018-01-10
就是三次,i=0、1、2
2018-01-15
老師的i++可以控制在if后面,跟后面else無關呀,打個比方從第二次開始輸,若一直重復可以輸無數次,你這樣寫,如果輸入重復的也算了
2018-01-14
for循環是可以用,但你這樣寫,只能輸入三次,無論id是否重復。
如果你把i++放入if里面,只要id重復,就能輸入多次,直到你正確輸入三個不重復的id為止。