Java連載66-數組的兩種初始化方式

1、數組java

1.數組中存儲元素的類型是統一的,每個元素在內存中所佔用的空間大小是相同的,知道數組的首元素的內存地址,要查找的元素只要知道下標,就能夠快速的計算出偏移量,經過首元素內存地址加上偏移量,就能夠快速計算出要查找元素的內存地址。經過內存地址快速定位該元素,因此數組查找元素的效率較高。node

2.隨機的對數組進行增刪元素,當增長元素的時候,爲了保證數組中元素在空間存儲上是有序的,因此被添加元素位置後面的全部元素都要向後移動,刪除元素也是,後面全部的元素要向前移動,因此數組的增刪元素​效率很低。git

3.​初始化一維數組,有兩種方式:github

(1)​靜態初始化;(2)動態初始化​。數組

 

package com.bjpowernode.java_learning;

​

public class D66_1_ {

  public static void main(String[] args) {

    //靜態初始化一個int類型的一維數組

    int[] a1 = {10,22,21};

    //取得第一個元素

    System.out.println("第一個元素:" + a1[0]);

    System.out.println("最後一個元素:" + a1[2]);

    System.out.println("最後一個元素:" + a1[a1.length-1]);

    //去的個數

    System.out.println("數組中的的元素個數爲:"+a1.length);

    //遍歷一維數組

    for(int i = 0;i<a1.length;i++) {

      System.out.println(a1[i]);

    }

    //將第二個元素改成100

    a1[1] = 100;

    System.out.println("===================");

    for(int i= 0;i<a1.length;i++) {

      System.out.println(a1[i]);

    }

  }

​

}

 

上面是使用靜態初始化一維數組,下面演示動態初始化一維數組微信

 

    int[] a2 = new int[4];

    //引用類型的數組

    Object[] objs = new Object[3];

    for(int index=0;index<objs.length;index++) {

      Object o = objs[index];

      //o.toString();//注意空指針異常

      System.out.println(o);//null null null這裏就沒有出現空指針異常,這是由於pirintln

      //這個函數的源碼裏面對這種空指針作了篩選,能夠見源碼

下面看一下println的源碼是如何處理這種空指針異常的函數

 

2、何時使用動態初始化,何時使用靜態初始化學習

1.不管是動態初始化仍是靜態初始化,最終的內存分佈都是同樣的。大數據

2.若是在建立數組的時候,知道數組中應該存儲什麼數據,這個時候固然採用靜態初始​化方式。若是在建立數組的時候,沒法預測到數組中存儲什麼數據,只是先開闢空間,​則使用動態初始化方式。ui

如下兩種初始化方式都是能夠的

int a3[] = {12,12,45};

int [] a3 = {12,12,45};

 

4、源碼:

D66_ArryInitialMethods.java

https://github.com/ruigege66/Java/blob/master/D66_ArryInitialMethods.java2.CSDN:https://blog.csdn.net/weixin_44630050

3.博客園:https://www.cnblogs.com/ruigege0000/

4.歡迎關注微信公衆號:傅里葉變換,我的公衆號,僅用於學習交流,後臺回覆」禮包「,獲取大數據學習資料

 

相關文章
相關標籤/搜索