201621123030《Java程序設計》第4周學習總結
1.本周學習總結
1.1寫出你認為本周學習中比較重要的知識點關鍵詞。
繼承,多態,super關鍵字,final關鍵字,super關鍵字,Object,instanceof,重載
1.2 嘗試使用思維導圖將這些關鍵詞組織起來。註:思維導圖一般不需要出現過多的字。
1.3 可選:使用常規方法總結其他上課內容。
2. 書面作業
1. 面向對象設計(大作業1-該作業將作為以後其他作業的基礎,請務必完成)
1.1 講故事:用50字以上講一個你在網上商城購物或者在班級博客進行學習的故事。使用Markdown的加粗標記把關鍵名詞標註出來,使用語句塊標記把裏面關鍵的動詞標註出來。講故事範例:見參考資料UML類圖中如何繪制類圖
剛開學打算上網買一本Java課本,還有幾只筆
在搜索框裏搜索Java課本,將賣的最多的加入了購物車
然後接著搜索了筆,將價格最低的加入購物車,最後打開購物車結算
1.2 找出系統中包含的類及其屬性、方法,類與類之間的關系,並繪制相應類圖。註意:不一定非要體現繼承關系。只要能將系統描述完整即可。一開始設計的時候不要考慮太多,不要出現太多的類,僅出現必要的類,完成最小功能即可。對商城購物系統建議只做購物車模塊。
1.3 使用Java代碼實現這個系統(不必很完善)。粘貼運行截圖與關鍵代碼。將來要在這個基礎上逐漸完善、擴展成一個完整的面向對象的系統。合作完成:2-3人一個小組。
可選:團隊協作可使用git與碼雲。在碼雲中新建項目。所有隊員都應在碼雲中該項目下均應有有提交記錄。截圖你們的提交記錄。
主要的購物車代碼:
public class User
{
private String userName;
private String password;
private Goods goods;
private String address;
}
2. ManagerTest.zip代碼分析(繼承、多態)
分析ManagerTest.zip中的代碼,回答幾個問題:
2.1 簡述文件中表現出的繼承關系。哪些是共有方法,哪些是子類特有的屬性和方法?
Employee是父類
公共方法有:
public String getName(){
}
public double getSalary(){
}
private double bonus就屬於子類的屬性
2.2 文件第26行e.getSalary()
,到底是調用Manager類的還是Employee類的getSalary方法?
staff被創建為Employee類,所以e.getSalary()調用的就是父類Employee類的getSalary(),如果當Manager對象被e引用的時候,e.getSalary()調用的就是Manger類中的getSalary方法。
2.3 Manager類的構造函數使用super調用父類的構造函數實現了代碼復用,這樣有什麽好處?為什麽不把父類構造函數中的相關代碼復制粘貼到Manager的構造函數中,這樣看起來不是更直觀嗎?
可以減少代碼的數量,避免重復地敲相同的代碼,代碼復用可以大大提高效率
為什麽不把父類構造函數中的相關代碼復制粘貼到Manager的構造函數中呢?
復制粘貼的效果相同,但如果我們需要修改父親函數時,這時需要對每一處你使用父類的代碼的地方進行修改,可能會出現遺漏,拖慢了進度,降低了效率
3. Object類中的toString與equals
3.1 編寫Fruit類,屬性String name。如果覆蓋其toString()方法,其父類中的toString方法的代碼就沒有了嗎?編寫Fruit的toString()方法,在該方法中要將調用父類的toString方法得到的字符串與自己特有的屬性name拼接起來,怎麽編寫?(使用代碼展示)
public String toString() {
return super.toString() +" \t" +"Fruit{" + "name = "+ name + ‘}‘;
}
3.2 為Fruit類編寫equals方法覆蓋父類相應方法,功能為當兩個Fruit對象name相同時(忽略大小寫),返回true。(使用代碼證明你自己覆蓋的equals方法是正確的)
打開Object類的eqauls方法的源代碼:
public boolean equals(Object obj) {
return (this == obj);
}
如果調用Object類的equals方法,需要先new兩個對象,這樣得到的答案是false,雖然對象名字相同,但對象是不同的。這樣 必然會讓人聯想到String類中也有個equals方法, 使用這個方法時,那我們得到的答案就是true。
Fruit[] fruits = new Fruit[2];
fruits[0] = new Fruit("apple") ;
fruits[1] = new Fruit("apple");
System.out.println(fruits[0].equals(fruits[1]));
運行結果為false;
String str1 = new String("apple");
String str2 = "apple";
System.out.println(str1.equals(str2));
運行結果為true。
為什麽同樣是equals方法,得到的答案卻是相反的呢?Object類的equals方法的本質其實是和“==”一樣的,都是比較兩個對象引用是否指向同一個對象(即兩個對象是否為同一對象);根據代碼,str1和str2都指向了內存中同一個有apple這個字符串的字符串池,那麽答案自然是true了。
接下來就重寫equals方法:
public boolean equals (Object object){
if (this == object)
return true;
if(!(object instanceof Fruit))
return false;
Fruit fruit = (Fruit )object;
if(this.name == null)
{
if (fruit.name != null)
return false;
}
else if(!this.name.equalsIgnoreCase(fruit.name))
return false;
return true ;
}
這段重寫代碼是自己寫的,後來我發現編譯器也會自己生成equals方法,並且還能附帶重新編寫哈希函數:
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + ((name == null) ? 0 : name.hashCode());
return result;
}
@Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Fruit other = (Fruit) obj;
if (name == null) {
if (other.name != null)
return false;
} else if (!name.equals(other.name))
return false;
return true;
}
如果這個輸入的類的對象不是我們所要的Fruit類,直接返回false;如果name為空,而輸入的name不為空,也返回false;為了忽略大小寫,我使用了String類裏的equalsIgnoreCase方法,只要是Object類中判定錯誤的,我就返回true。
我的兩個對象分別是:
這樣的運行結果自然就是true
3.3 完成3.2後,使用ArrayList
提示:直接使用ArrayList的contains方法實現判斷對象是否存在。
運行結果:
4. 實驗總結:
4.1 PTA編程題(形狀-繼承)。並回答:在本題中使用多態為編程帶來了什麽好處?
多態對代碼編寫修改簡化了很多,還有可替性,減少了編寫時間
4.2 PTA編程題(覆蓋)。並回答:編寫eqauls方法是需要註意些什麽?
equals編寫的時候要記住不能忘記null的情況
4.3 程序填空、函數題(1-3)
6-1要用super調用父類的toString
6-2 這題就根據題目要求一步一步來,最後是倒序輸出數組如果null就不輸出
6-3 這題用到equals的方法,自動生成後記得要修改slary的部分
3. 碼雲及PTA
3.1. 碼雲代碼提交記錄
- 在碼雲的項目中,依次選擇“統計-Commits歷史-設置時間段”, 然後搜索並截圖
3.2 截圖PTA題集完成情況圖
本周完成(形狀-繼承,覆蓋)
需要有兩張圖(1. 排名。2.PTA提交列表)
3.3 統計本周完成的代碼量
需要將每周的代碼統計情況融合到一張表中。
周次 | 總代碼量 | 新增代碼量 | 總文件數 | 新增文件數 |
---|---|---|---|---|
2 | 330 | 330 | 5 | 5 |
3 | 625 | 322 | 11 | 6 |
4 | 1047 | 422 | 16 | 5 |
201621123030《Java程序設計》第4周學習總結