1. 程式人生 > >201621123030《Java程序設計》第4周學習總結

201621123030《Java程序設計》第4周學習總結

1.3 3.1 super 字符 ng- public contain 忘記 設置時間

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方法的本質其實是和“==”一樣的,都是比較兩個對象引用是否指向同一個對象(即兩個對象是否為同一對象);根據代碼,str1str2都指向了內存中同一個有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周學習總結