子類繼承父類,那么各代碼塊的執行順序為:


子類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定義的方法沒有實現,必須被子類重寫,明顯不能一起使用。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM