Java 數(shù)組的兩種初始化方式
一、數(shù)組
1.數(shù)組中存儲(chǔ)元素的類型是統(tǒng)一的,每一個(gè)元素在內(nèi)存中所占用的空間大小是相同的,知道數(shù)組的首元素的內(nèi)存地址,要查找的元素只要知道下標(biāo),就可以快速的計(jì)算出偏移量,通過(guò)首元素內(nèi)存地址加上偏移量,就可以快速計(jì)算出要查找元素的內(nèi)存地址。通過(guò)內(nèi)存地址快速定位該元素,所以數(shù)組查找元素的效率較高。
2.隨機(jī)的對(duì)數(shù)組進(jìn)行增刪元素,當(dāng)增加元素的時(shí)候,為了保證數(shù)組中元素在空間存儲(chǔ)上是有序的,所以被添加元素位置后面的所有元素都要向后移動(dòng),刪除元素也是,后面所有的元素要向前移動(dòng),所以數(shù)組的增刪元素效率很低。
3.初始化一維數(shù)組,有兩種方式:
(1)靜態(tài)初始化;
(2)動(dòng)態(tài)初始化。
package com.bjpowernode.java_learning;
public class D66_1_ {
public static void main(String[] args) {
//靜態(tài)初始化一個(gè)int類型的一維數(shù)組
int[] a1 = {10,22,21};
//取得第一個(gè)元素
System.out.println("第一個(gè)元素:" + a1[0]);
System.out.println("最后一個(gè)元素:" + a1[2]);
System.out.println("最后一個(gè)元素:" + a1[a1.length-1]);
//去的個(gè)數(shù)
System.out.println("數(shù)組中的的元素個(gè)數(shù)為:"+a1.length);
//遍歷一維數(shù)組
for(int i = 0;i<a1.length;i++) {
System.out.println(a1[i]);
}
//將第二個(gè)元素改為100
a1[1] = 100;
System.out.println("===================");
for(int i= 0;i<a1.length;i++) {
System.out.println(a1[i]);
}
}
}

上面是使用靜態(tài)初始化一維數(shù)組,下面演示動(dòng)態(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這里就沒(méi)有出現(xiàn)空指針異常,這是因?yàn)閜irintln
//這個(gè)函數(shù)的源碼里面對(duì)這種空指針做了篩選,可以見(jiàn)源碼

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


二、什么時(shí)候使用動(dòng)態(tài)初始化,什么時(shí)候使用靜態(tài)初始化
1.無(wú)論是動(dòng)態(tài)初始化還是靜態(tài)初始化,最終的內(nèi)存分布都是一樣的。
2.如果在創(chuàng)建數(shù)組的時(shí)候,知道數(shù)組中應(yīng)該存儲(chǔ)什么數(shù)據(jù),這個(gè)時(shí)候當(dāng)然采用靜態(tài)初始化方式。如果在創(chuàng)建數(shù)組的時(shí)候,無(wú)法預(yù)測(cè)到數(shù)組中存儲(chǔ)什么數(shù)據(jù),只是先開(kāi)辟空間,則使用動(dòng)態(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ù)組初始化的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
java應(yīng)用cpu飆升(超過(guò)100%)故障排查步驟
在Java并發(fā)編程計(jì)算密集型要進(jìn)行大量的計(jì)算、邏輯判斷等操作,消耗CPU資源,比如計(jì)算圓周率、對(duì)視頻進(jìn)行高清解碼等等,下面這篇文章主要給大家介紹了關(guān)于java應(yīng)用cpu飆升(超過(guò)100%)故障排查步驟的相關(guān)資料,需要的朋友可以參考下2023-06-06
SpringBoot3整合郵件服務(wù)實(shí)現(xiàn)郵件發(fā)送功能
本文介紹了spring boot整合email服務(wù),實(shí)現(xiàn)發(fā)送驗(yàn)證碼,郵件(普通文本郵件、靜態(tài)資源郵件、附件郵件),文中通過(guò)代碼示例介紹的非常詳細(xì),堅(jiān)持看完相信對(duì)你有幫助,需要的朋友可以參考下2024-05-05
SpringBoot使用Redis的zset統(tǒng)計(jì)在線用戶信息
這篇文章主要介紹了SpringBoot使用Redis的zset統(tǒng)計(jì)在線用戶信息,幫助大家更好的理解和學(xué)習(xí)使用SpringBoot框架,感興趣的朋友可以了解下2021-04-04
詳解Java如何實(shí)現(xiàn)FP-Growth算法
學(xué)校里的實(shí)驗(yàn),要求實(shí)現(xiàn)FP-Growth算法.FP-Growth算法比Apriori算法快很多(但是卻比不上時(shí)間)在網(wǎng)上搜索后發(fā)現(xiàn)Java實(shí)現(xiàn)的FP-Growth算法很少,且大多數(shù)不太能理解):太菜.所以就自己實(shí)現(xiàn)了一下.這篇文章重點(diǎn)介紹一下我的Java實(shí)現(xiàn) ,需要的朋友可以參考下2021-06-06
spring boot項(xiàng)目如何采用war在tomcat容器中運(yùn)行
這篇文章主要介紹了spring boot項(xiàng)目如何采用war在tomcat容器中運(yùn)行呢,主要講述將SpringBoot打成war包并放入tomcat中運(yùn)行的方法分享,需要的朋友可以參考下2022-11-11
JUnit5中的參數(shù)化測(cè)試實(shí)現(xiàn)
參數(shù)化測(cè)試使得我們可以使用不同的參數(shù)運(yùn)行同一個(gè)測(cè)試方法,從而減少我們編寫測(cè)試用例的工作量,本文主要介紹了JUnit5中的參數(shù)化測(cè)試實(shí)現(xiàn),感興趣的可以了解一下2023-05-05
使用JAVA+Maven+TestNG框架實(shí)現(xiàn)超詳細(xì)Appium測(cè)試安卓真機(jī)教程
這篇文章主要介紹了使用JAVA+Maven+TestNG框架實(shí)現(xiàn)超詳細(xì)Appium測(cè)試安卓真機(jī)教程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01
Java NIO Selector用法詳解【含多人聊天室實(shí)例】
這篇文章主要介紹了Java NIO Selector用法,結(jié)合實(shí)例形式分析了Java NIO Selector基本功能、原理與使用方法,并結(jié)合了多人聊天室實(shí)例加以詳細(xì)說(shuō)明,需要的朋友可以參考下2019-11-11

