子類A繼承父類B, A a = new A(); 則父類B構造函數、父類B靜態代碼塊、父類B非靜態代碼塊、子類A構造函數、子類A靜態代碼塊、子類A非靜態代碼塊 執行的先后順序是:
-
父類B靜態代碼塊->子類A靜態代碼塊->父類B非靜態代碼塊->父類B構造函數->子類A非靜態代碼塊->子類A構造函數
解析:
按照先后順序:
1,靜態先於非靜態代碼庫執行(靜態代碼塊隨着類的加載而加載,初始化只執行一次)
2,父類先於子類
3,非靜態代碼塊優於構造函數執行
-----------------------------------------------------------------------------------------------------------------------------
ArraryList 與linkedList的區別:
ArraryList:1.
ArrayList是基於數組的,所以,具備隨機訪問特點;
2.ArrayList插入或刪除一個元素的開銷不是固定的。在插入時,如果索引正確,容量夠,則直接插入,插入位置之后的都需要移動,如果容量不夠,還得擴充容量,開銷當然不一樣。刪除操作同理。
linkedList:1.也可以通過也支持隨機訪問,但卻付出了一定的代價。在LinkedList中,如果想返回某個位置的元素,就是從前往后遍歷。如下。很明顯,
LinkedLIst不支持高效的隨機訪問
2.
LinkedList是基於雙鏈表的,增加是在尾部增加,增加和刪除都只需要修改指針,不需要移動元素。
Node<E> node(int index) { // assert isElementIndex(index); if (index < (size >> 1)) { Node<E> x = first; for (int i = 0; i < index; i++) x = x.next; return x; } else { Node<E> x = last; for (int i = size - 1; i > index; i--) x = x.prev; return x; } }
----------------------------------------------------------------------------------------------------------------------------
A :錯誤
default String s
變量不能被defalut修飾
B:正確
public final static native int w( )
native修飾方法,native修飾的方法簡單來說就是:一個Java方法調用了一個非Java代碼的接口。
定義navtive方法時,並不提供實現體,因為其實現體是用非Java語言在外面實現的。native可以和任何修飾符連用,abstract除外。因為native暗示這個方法時有實現體的,而abstract卻顯式指明了這個方法沒有實現體。
C:錯誤
abstract double d
abstract修飾方法和類
D:錯誤
abstract final double hyperbolicCosine( )
final修飾的方法不能被重寫。而abstract定義的方法沒有實現,必須被子類重寫,明顯不能一起使用。