知識點 關鍵字,常用類(super,static,final): super 子類對父類的引用,只能在非靜態方法中使用 引用父類的成員變數的格式為 super.成員變數名稱 引用父類的非靜態方法的格式為 super.方法名(參數列表) 引用父類的構造方法的格式為 super(參數列表) final ...
知識點
關鍵字,常用類(super,static,final):
super
- 子類對父類的引用,只能在非靜態方法中使用
- 引用父類的成員變數的格式為 super.成員變數名稱
- 引用父類的非靜態方法的格式為 super.方法名(參數列表)
- 引用父類的構造方法的格式為 super(參數列表)
final
- final修飾類這個類就不能被繼承,但不影響創建對象,如系統的String類
- final修飾的方法不能被重寫,但父類中沒有被final修飾方法,子類覆蓋後可以加final。
- final修飾局部變數,只能夠賦值一次,當修飾的是引用的類型時,不能被重新賦值,但是可以修改對象的屬性
- final修飾成員變數,最終的變數,常量,固定的值,一定要初始化,不能被二次賦值。
static(開發中慎用,會很耗記憶體)
- 靜態的,成員信息在類中在方法區中,常量池(常量值),靜態記憶體區(靜態成員信息)。
- 不能修飾類,但是可以修飾方法,該方法是靜態方法,在類中,通過類區執行調用。
- 被static修飾的變數,是靜態變數,在類中。靜態全局變數:靜態屬性-->在類中存儲,被所有對象共用。
思考:super,this 與 static 為什麼不能共存????
static靜態的,是不變的,在java中static修飾成員屬性,方法時,表示該屬性/方法可以被類名直接調用,如工具類等
而this代表本類對象的引用,通常用與成員變數與局部變數重名時。
super代表子類對父類滿參構造函數的初始化,也是需要產生對象才可以使用但是考慮到虛擬機載入順序為先載入類,當被實例化才產生對象。所以如果並存則表示類和對象同時載入,顯然是不合邏輯的。
代碼塊:
- 局部代碼塊
- 定義在方法中,用戶劃分區域的。( {}:作用域啊,劃定工作區間 )
- 構造代碼塊
- 構造代碼塊和方法併列,定義在類成員變數位置的代碼塊,每次創建對象的時候都會執行,優先於構造方法
- 內容寫的是語句,聲明變數,不能實現功能體(方法)。
- 靜態代碼塊
- 定義在類的成員變數位置的用static修飾的代碼塊。
- 它優先於當前類主方法執行、優先於構造代碼塊執行,當以任意形式第一次使用到該類時執行。
- 該類不管創建多少對象,靜態代碼塊只執行一次。
- 可用於給靜態變數賦值,用來給類進行初始化,初始化成員變數,載入一些成員信息。
執行順序:父類靜態代碼塊>子類靜態代碼塊>main函數>構造代碼塊>構造方法
(註意:方法只能併列使用,不能嵌套使用!!!!!!!!!)
訪問修飾符
–-------------- | public | protected | default | private |
同一類中 | ✔ | ✔ | ✔ | ✔ |
同一包中 (子類與無關類) |
✔ | ✔ | ✔ | |
不同包的子類 | ✔ | ✔ | ||
不同包中的無 關類 | ✔ |
註意:
-
對於protected不同包中的子類只能在子類內部調用,在外部子類是無法調用成員變數和方法的
-
在不同包下的無關類中,只能訪問public修飾的成員信息
-
在不同包的子類中,子類的對象是可以訪問被protected修飾的父類的成員信息的
系統常用類:
API ---> Application Interface 應用程式介面
java中的五大常用包: java.lang、 java.util、 java.io、 java.net、 java.sql
object類
equals
方法在非空對象引用上實現等價關係:
- 自反性 :對於任何非空的參考值
x
,x.equals(x)
應該返回true
。 - 它是對稱的 :對於任何非空引用值
x
和y
,x.equals(y)
應該返回true
當且僅當y.equals(x)
回報true
。 - 傳遞性 :對於任何非空引用值
x
,y
和z
,如果x.equals(y)
回報true
個y.equals(z)
回報true
,然後x.equals(z)
應該返回true
。 - 它是一致的 :對於任何非空引用值
x
和y
,多次調用x.equals(y)
始終返回true
或始終返回false
,沒有設置中使用的信息equals
比較上的對象被修改。 - 對於任何非空的參考值
x
,x.equals(null)
應該返回false
。 - 該
equals
類方法Object
實現對象上差別可能性最大的相等關係; 也就是說,對於任何非空的參考值x
和y
,當且僅當x
和y
引用相同的對象(x == y
具有值true
)時,該方法返回true
。 - 請註意,無論何時覆蓋該方法,通常需要覆蓋
hashCode
方法,以便維護hashCode
方法的通用合同,該方法規定相等的對象必須具有相等的哈希碼。
toString
方法返回一個“textually代表”這個對象的字元串。 結果應該是一個簡明扼要的表達,容易讓人閱讀。 建議所有子類覆蓋此方法。
該toString
類方法Object
返回一個由其中的對象是一個實例,該符號字元`的類的名稱的字元串@
”
和對象的哈希碼的無符號的十六進位表示。
換句話說,這個方法返回一個等於下列值的字元串:
getClass().getName() + '@' + Integer.toHexString(hashCode())
string類
-
String
類代表字元串。 Java程式中的所有字元串文字(例如"abc"
)都被實現為此類的實例。 -
字元串不變; 它們的值在創建後不能被更改。 字元串緩衝區支持可變字元串。
-
因為String對象是不可變的,它們可以被共用。
練習代碼:
/* 自己創建一個類,寫一個靜態方法,傳入一個int數組,得 到一個字元串[元素1,元素2,….] */ public class HomeWork02 { public static void main(String[] args) { int[] arr = new int[]{1,55,66,99,88,74,22,44,32,22}; System.out.print("["); for (int i = 0;i<arr.length;i++){ if (i!=arr.length-1){ System.out.print(arr[i]+","); }else { System.out.print(arr[i]); } } System.out.println("]"); } }
public class HomeWork01 { public static void main(String[] args) { // 在控制台輸入字元串,統計出大寫的字元的個數,小寫的字元個數,數字類型的字元個數,以及其他字元的個數 Scanner sc = new Scanner(System.in); int big = 0; int small = 0; int num = 0; int other = 0; System.out.println("請輸入一串字元串"); String str = sc.next(); for (int i = 0; i < str.length(); i++) { if (str.charAt(i) >= 65 && str.charAt(i) <= 90) { big++; } else if (str.charAt(i) >= 97 && str.charAt(i) <= 122) { small++; } else if (str.charAt(i) >= 48 && str.charAt(i) <= 57) { num++; } else { other++; } } System.out.println("大寫字母有:" + big + "個"); System.out.println("小寫字母有:" + small + "個"); System.out.println("數字有:" + num + "個"); System.out.println("其他字元有:" + other + "個"); } }