徐思201771010132《面向對象程序設計(java)》第七周學習總結
一、理論知識部分
訪問修飾符:private:只有該類可以訪問 protected:該類及其子類的成員可以訪問,同一個包中的類也可訪問 public:該類或非該類均可訪問 默認:相同包中的類可以訪問
註:不寫訪問修飾符時默認為friendly
Object類是Java中所有類的祖先——每一個類都由它擴展而來。在不給出超類的情況下,Java會自動把Object 作為要定義類的超類。可以使用類型為Object的變量指向任意類型的對象。但要對它們進行專門的操作都要進行類型轉換。
Object類中的equals方法用於測試某個對象是否同另一個對象相等。它在Object類中的實現是判斷兩個對象是否具有相同的引用。如果兩個對象具有相同的引用,它們一定是相等的。
Object類中的hashCode方法導出某個對象的散列碼。散列碼是任意整數,表示對象的存儲地址。兩個相等對象的散列碼相等。
Object類的toString方法返回一個代表該對象域值的字符串。toString方法返回字符串的格式:類名,然後在方括號中列舉域值。通過 getClass().getName()獲得類名的字符串。
toString的調用方式:一個字符串與對象名通過操作符“+”連接起來,就會自動調用toString方法。 String message = “The current employee is”+x;
如果x是任意一個對象,調用System.out.println(x),就會直接地調用x.toString(),並打印輸出字符串。
定義子類的toString方法時,可先調用超類的toString方法。super.toString( )
Java中,利用ArrayList類,可允許程序在運行時確定數組的大小。ArryList是一個采用類型參數的泛型類。為指定數組列表保存元素的對象類型,需要用一對尖括號將數組元素對象類名括起來加在後面。 ArryList staff=new ArrayList();
沒有<>的ArrayList將被認為是一個刪去了類型參數的“原始”類型。
所有基本數據類型都有著與之對應的預定義類,它們被稱為對象包裝器(wrapper)。對象包裝器類是不可變的,即一旦構造了包裝器,就不允許更改包裝在其中的值。且對象包裝器類還是final,因此不能定義它們的子類。
使用對象包裝器的好處:基本類型轉化為對象;定義一些有用的基本方法(static方法)。
聲明枚舉類 public enum Grade { A, B, C, D, E };
它包括一個關鍵字enum,一個新枚舉類型的名字 Grade以及為Grade定義的一組值,這裏的值既非整型,亦非字符型。
枚舉類說明:枚舉類是一個類,它的隱含超類是java.lang.Enum。枚舉值並不是整數或其它類型,是被聲明的枚舉類的自身實例。枚舉類不能有public修飾的構造函數,構造函數都是 隱含private,編譯器自動處理。枚舉值隱含都是由public、static、final修飾的,無須自己添加這些修飾符。在比較兩個枚舉類型的值時,永遠不需要調用 equals 方法,直接使用"=="進行相等比較。
二、實驗部分
1、實驗目的與要求
(1)進一步理解4個成員訪問權限修飾符的用途;
(2)掌握Object類的常用API用法;
(3)掌握ArrayList類用法與常用API;
(4)掌握枚舉類使用方法;
(5)結合本章知識,理解繼承與多態性兩個面向對象
程序設計特征,並體會其優點;
(6)熟練掌握Java語言中基於類、繼承技術構造程序的語法知識(ch1-ch5);
(7)利用已掌握Java語言程序設計知識,學習設計開發含有1個主類、2個以上用戶自定義類的應用程序。
2、實驗內容和步驟
實驗1 補充以下程序中主類內main方法體,以驗證四種權限修飾符的用法。
public class TEST1 { private String t1 = "這是TEST1的私有屬性"; public String t2 = "這是TEST1的公有屬性"; protected String t3 = "這是TEST1受保護的屬性"; String t4 = "這是TEST1的默認屬性"; private void tese1() { System.out.println("我是TEST1用private修飾符修飾的方法"); } public void tese2() { System.out.println("我是TEST1用public修飾符修飾的方法"); } protected void tese3() { System.out.println("我是TEST1用protected修飾符修飾的方法"); } void tese4() { System.out.println("我是TEST1無修飾符修飾的方法"); } } public class TEST2 extends TEST1{ private String e1 = "這是TEST2的私有屬性"; public String e2 = "這是TEST2的公有屬性"; protected String e3 = "這是TEST2受保護的屬性"; String e4 = "這是TEST2的默認屬性"; public void demo1() { System.out.println("我是TEST2用public修飾符修飾的方法"); } private void demo2() { System.out.println("我是TEST2用private修飾符修飾的方法"); } protected void demo3() { System.out.println("我是TEST2用protected修飾符修飾的方法"); } void demo4() { System.out.println("我是TEST2無修飾符修飾的方法"); } } public class Main { public static void main(String[] args) { TEST2 test2 = new TEST2(); /*以下設計代碼分別調用 demo1 demo2 demo3 demo4 test1 test2 test3 test4方法和t1 t2 t3 t3 e1 e2 e3 e4屬性,結合程序運行結果理解繼承和權限修飾符的用法與區別*/ } } |
public class TEST1 { private String t1 = "這是TEST1的私有屬性"; public String t2 = "這是TEST1的公有屬性"; protected String t3 = "這是TEST1受保護的屬性"; String t4 = "這是TEST1的默認屬性"; private void test1() { System.out.println("我是TEST1用private修飾符修飾的方法"); } public void test2() { System.out.println("我是TEST1用public修飾符修飾的方法"); } protected void test3() { System.out.println("我是TEST1用protected修飾符修飾的方法"); } void test4() { System.out.println("我是TEST1無修飾符修飾的方法"); } } public class TEST2 extends TEST1{ private String e1 = "這是TEST2的私有屬性"; public String e2 = "這是TEST2的公有屬性"; protected String e3 = "這是TEST2受保護的屬性"; String e4 = "這是TEST2的默認屬性"; public void demo1() { System.out.println("我是TEST2用public修飾符修飾的方法"); } private void demo2() { System.out.println("我是TEST2用private修飾符修飾的方法"); } protected void demo3() { System.out.println("我是TEST2用protected修飾符修飾的方法"); } void demo4() { System.out.println("我是TEST2無修飾符修飾的方法"); } } public class Main { public static void main(String[] args) { TEST2 test2 = new TEST2(); /*在下面分別調用 demo1 demo2 demo3 demo4 test1 test2 test3 test4方法 和 t1 t2 t3 t4 e1 e2 e3 e4屬性,好好理解繼承和權限修飾符的用法與區別*/ //demo2 test1 t1 e1是用private修飾符修飾的,不能被訪問 test2.demo1(); test2.demo3(); test2.demo4(); test2.test2(); test2.test3(); test2.test4(); System.out.println(test2.t2); System.out.println(test2.t3); System.out.println(test2.t4); System.out.println(test2.e2); System.out.println(test2.e3); System.out.println(test2.e4); } }
實驗2 第五章測試程序反思,繼承知識總結。
測試程序1:
? 編輯、編譯、調試運行教材程序5-8、5-9、5-10(教材174頁-177頁);
? 結合程序運行結果,理解程序代碼,掌握Object類的定義及用法;
package equals; /** * This program demonstrates the equals method. * @version 1.12 2012-01-26 * @author Cay Horstmann */ public class EqualsTest { public static void main(String[] args) { Employee alice1 = new Employee("Alice Adams", 75000, 1987, 12, 15); Employee alice2 = alice1; Employee alice3 = new Employee("Alice Adams", 75000, 1987, 12, 15); Employee bob = new Employee("Bob Brandson", 50000, 1989, 10, 1); System.out.println("alice1 == alice2: " + (alice1 == alice2)); System.out.println("alice1 == alice3: " + (alice1 == alice3)); System.out.println("alice1.equals(alice3): " + alice1.equals(alice3)); System.out.println("alice1.equals(bob): " + alice1.equals(bob)); System.out.println("bob.toString(): " + bob); Manager carl = new Manager("Carl Cracker", 80000, 1987, 12, 15); Manager boss = new Manager("Carl Cracker", 80000, 1987, 12, 15); boss.setBonus(5000); System.out.println("boss.toString(): " + boss); System.out.println("carl.equals(boss): " + carl.equals(boss)); System.out.println("alice1.hashCode(): " + alice1.hashCode()); System.out.println("alice3.hashCode(): " + alice3.hashCode()); System.out.println("bob.hashCode(): " + bob.hashCode()); System.out.println("carl.hashCode(): " + carl.hashCode()); } }
package equals; import java.time.*; import java.util.Objects; public class Employee { private String name; private double salary; private LocalDate hireDay; public Employee(String name, double salary, int year, int month, int day) { this.name = name; this.salary = salary; hireDay = LocalDate.of(year, month, day); } public String getName() { return name; } public double getSalary() { return salary; } public LocalDate getHireDay() { return hireDay; } public void raiseSalary(double byPercent) { double raise = salary * byPercent / 100; salary += raise; } public boolean equals(Object otherObject) { // 快速測試以確定對象是否相同 if (this == otherObject) return true;//檢測this與otherObject是否引用同一個對象 // 如果顯示參數為null,則返回false if (otherObject == null) return false;//檢測otherObject是否為null,如果為null,返回false //如果類不匹配,他們不可能相等 if (getClass() != otherObject.getClass()) return false;//比較this與otherObject是否屬於同一個類。如果equals的語義在每個子類中有所改變,就使用getClass檢測 // 現在我們知道其他的對象是一個非空Employee Employee other = (Employee) otherObject;//將otherObject轉換為相應的類類型變量 // 檢測是否有相同的值 return Objects.equals(name, other.name) && salary == other.salary && Objects.equals(hireDay, other.hireDay);//Objects.quals方法防備參數可能為null的情況 } public int hashCode() { return Objects.hash(name, salary, hireDay); } //Employee類中的toString方法的實現。通過調用getClass().getName()獲得類名的字符串 public String toString() { return getClass().getName() + "[name=" + name + ",salary=" + salary + ",hireDay=" + hireDay + "]"; } }
package equals; public class Manager extends Employee { private double bonus; public Manager(String name, double salary, int year, int month, int day) { super(name, salary, year, month, day); bonus = 0; } public double getSalary() { double baseSalary = super.getSalary(); return baseSalary + bonus; } public void setBonus(double bonus) { this.bonus = bonus; } //調用超類的equals public boolean equals(Object otherObject) { if (!super.equals(otherObject)) return false; Manager other = (Manager) otherObject; // super.equals檢查這個和其他屬於同一個類 return bonus == other.bonus; } public int hashCode() { return java.util.Objects.hash(super.hashCode(), bonus); } //toString方法也可以供子類調用 public String toString() { return super.toString() + "[bonus=" + bonus + "]";// } }
測試程序2:
? 編輯、編譯、調試運行教材程序5-11(教材182頁);
? 結合程序運行結果,理解程序代碼,掌握ArrayList類的定義及用法;
package arrayList; import java.util.*; /** * This program demonstrates the ArrayList class. * @version 1.11 2012-01-26 * @author Cay Horstmann */ public class ArrayListTest { public static void main(String[] args) { //用三個雇員Employee對象ArrayList填充人員數組列表<Employee> ArrayList<Employee> staff = new ArrayList<>();//構造和聲明一個保存Employee對象的數組列表。結合new操作符使用菱形語法,如果賦值給一個變量,或傳遞到某種方法,
或者從某個方法返回,編譯器會檢查這個變量、參數或方法的泛型類型,然後將這個類型放在<>中。 //使用add方法將雇員對象添加到數組列表中 staff.add(new Employee("Carl Cracker", 75000, 1987, 12, 15)); staff.add(new Employee("Harry Hacker", 50000, 1989, 10, 1)); staff.add(new Employee("Tony Tester", 40000, 1990, 3, 15)); // 提高每人5%的工資 for (Employee e : staff) e.raiseSalary(5); // 輸出關於所有Employee對象的信息 for (Employee e : staff) System.out.println("name=" + e.getName() + ",salary=" + e.getSalary() + ",hireDay=" + e.getHireDay()); } }
package arrayList; import java.time.*; public class Employee { private String name; private double salary; private LocalDate hireDay; public Employee(String name, double salary, int year, int month, int day) { this.name = name; this.salary = salary; hireDay = LocalDate.of(year, month, day); } public String getName() { return name; } public double getSalary() { return salary; } public LocalDate getHireDay() { return hireDay; } public void raiseSalary(double byPercent) { double raise = salary * byPercent / 100; salary += raise; } }
測試程序3:
? 編輯、編譯、調試運行程序5-12(教材189頁);
? 結合運行結果,理解程序代碼,掌握枚舉類的定義及用法;
package enums; import java.util.*; /** * This program demonstrates enumerated types. * @version 1.0 2004-05-24 * @author Cay Horstmann */ public class EnumTest { public static void main(String[] args) { Scanner in = new Scanner(System.in); System.out.print("Enter a size: (SMALL, MEDIUM, LARGE, EXTRA_LARGE) "); String input = in.next().toUpperCase(); Size size = Enum.valueOf(Size.class, input); System.out.println("size=" + size); System.out.println("abbreviation=" + size.getAbbreviation()); if (size == Size.EXTRA_LARGE) System.out.println("Good job--you paid attention to the _."); } } //枚舉類型 enum Size { SMALL("S"), MEDIUM("M"), LARGE("L"), EXTRA_LARGE("XL"); private Size(String abbreviation) { this.abbreviation = abbreviation; } public String getAbbreviation() { return abbreviation; } private String abbreviation; }
實驗3:采用個人賬號登錄https://pintia.cn/,完成《2018秋季西北師範大學面向對象程序設計(Java)(ch1-ch5)測試題2》,測試時間60分鐘;
實驗4: 課後完成實驗3未完成的測試內容。
三、實驗總結:通過這次實驗,我理解了4個成員訪問權限修飾符的用途以及繼承; 通過實驗和課本知識的結合,更好的掌握了Object類的定義及用法、ArrayList類的定義及用法、枚舉類的定義及用法。通過測試表明對之前知識掌握的不夠好,編程仍需努力,之前忽略了課本知識,對一些理論知識掌握不夠透徹,這些都需要學習。
徐思201771010132《面向對象程序設計(java)》第七周學習總結