Java 數(shù)組的兩種初始化方式
1.數(shù)組中存儲元素的類型是統(tǒng)一的,每一個元素在內(nèi)存中所占用的空間大小是相同的,知道數(shù)組的首元素的內(nèi)存地址,要查找的元素只要知道下標(biāo),就可以快速的計算出偏移量,通過首元素內(nèi)存地址加上偏移量,就可以快速計算出要查找元素的內(nèi)存地址。通過內(nèi)存地址快速定位該元素,所以數(shù)組查找元素的效率較高。
2.隨機的對數(shù)組進行增刪元素,當(dāng)增加元素的時候,為了保證數(shù)組中元素在空間存儲上是有序的,所以被添加元素位置后面的所有元素都要向后移動,刪除元素也是,后面所有的元素要向前移動,所以數(shù)組的增刪元素效率很低。
3.初始化一維數(shù)組,有兩種方式:
(1)靜態(tài)初始化;
(2)動態(tài)初始化。
package com.bjpowernode.java_learning;public class D66_1_ { public static void main(String[] args) { //靜態(tài)初始化一個int類型的一維數(shù)組 int[] a1 = {10,22,21}; //取得第一個元素 System.out.println('第一個元素:' + a1[0]); System.out.println('最后一個元素:' + a1[2]); System.out.println('最后一個元素:' + a1[a1.length-1]); //去的個數(shù) System.out.println('數(shù)組中的的元素個數(shù)為:'+a1.length); //遍歷一維數(shù)組 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]); } }}
上面是使用靜態(tài)初始化一維數(shù)組,下面演示動態(tài)初始化一維數(shù)組
int[] a2 = new int[4]; //引用類型的數(shù)組 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這里就沒有出現(xiàn)空指針異常,這是因為pirintln //這個函數(shù)的源碼里面對這種空指針做了篩選,可以見源碼
下面看一下println的源碼是如何處理這種空指針異常的
1.無論是動態(tài)初始化還是靜態(tài)初始化,最終的內(nèi)存分布都是一樣的。
2.如果在創(chuàng)建數(shù)組的時候,知道數(shù)組中應(yīng)該存儲什么數(shù)據(jù),這個時候當(dāng)然采用靜態(tài)初始化方式。如果在創(chuàng)建數(shù)組的時候,無法預(yù)測到數(shù)組中存儲什么數(shù)據(jù),只是先開辟空間,則使用動態(tài)初始化方式。
以下兩種初始化方式都是可以的
int a3[] = {12,12,45};int [] a3 = {12,12,45};三、源碼:
D66_ArryInitialMethods.java
https://github.com/ruigege66/Java/blob/master/D66_ArryInitialMethods.java
以上就是Java 數(shù)組的兩種初始化方式的詳細(xì)內(nèi)容,更多關(guān)于Java 數(shù)組初始化的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
