java中的數(shù)組初始化賦初值方式
java數(shù)組初始化賦初值
方法一
int[] vis1;//聲明未初始化? ?? ?vis1=new int[100];//定義占用空間大小(100個(gè)int) ?? ?for(int i=1;i<=5;i++) ?? ?{ ?? ??? ?vis1[i]=i;//進(jìn)行賦值 ?? ?} ?? ?for(int i=1;i<100;i++) ?? ?{ ?? ??? ?System.out.print(vis1[i]+" ");//輸出,未賦值的為0 ?? ?} ?? ?System.out.println(vis1.length);//輸出vis1數(shù)組的長(zhǎng)度
方法二
? ? int[] vis2={1,2,3,4,5}; ?? ?for(int i=0;i<5;i++) ?? ?{ ?? ??? ?System.out.print(vis2[i]); ?? ?} ?? ?System.out.println(vis2.length);
方法三
? ? int[] vis3=new int[]{1,2,3,4,5,6}; ?? ?System.out.println(vis3.length);
數(shù)組互相賦值方式
本文探討Java中數(shù)組中的賦值問(wèn)題。在探討這個(gè)問(wèn)題之前必須先弄懂一件事,Java中的數(shù)組到底是什么東西?是類,是對(duì)象,還是什么其他奇奇怪怪的東西。答案是:Java中的數(shù)組本質(zhì)上是對(duì)象。但是這個(gè)對(duì)象不是通過(guò)某個(gè)類實(shí)例化來(lái)的,而是JVM創(chuàng)建的,這也就不難解釋對(duì)于一個(gè)數(shù)組對(duì)象arr,我們可以直接通過(guò)arr.length訪問(wèn)數(shù)組的長(zhǎng)度。
現(xiàn)在我們知道了Java中數(shù)組本質(zhì)上是對(duì)象,那么我們來(lái)看一下這樣的代碼合理不合理:
int[] a = {1,2,3}; int[] b = new int[3]; b = a; for(int i = 0; i < a.length; i++) a[i] = 0;
我們本來(lái)的想法是把a(bǔ)數(shù)組的值賦值給b,然后將a數(shù)組清零,但是我們會(huì)發(fā)現(xiàn)a,b數(shù)組都被清零了。
既然數(shù)組本質(zhì)是對(duì)象,那么我們來(lái)分析一下這兩句代碼在Java內(nèi)存模型中發(fā)生了什么。
int[] a = {1,2,3};的時(shí)候,堆中會(huì)生成一個(gè)對(duì)應(yīng)的對(duì)象,a會(huì)指向這個(gè)對(duì)象,然后int[] b = new int[3];的時(shí)候,b也會(huì)指向這個(gè)對(duì)象。那么比如我們?cè)趯?duì)a[0]進(jìn)行修改的時(shí)候,實(shí)際上是對(duì)堆中對(duì)象做出了修改。b數(shù)組仍然是指向這個(gè)堆中對(duì)象的,當(dāng)然b數(shù)組的值也改變了。
說(shuō)到這里已經(jīng)顯而易見(jiàn)了,這樣實(shí)際上不太合理,比較兩個(gè)引用都是指向同一個(gè)堆中對(duì)象,其中一個(gè)修改必然會(huì)導(dǎo)致另一個(gè)的修改。
那么數(shù)組的賦值究竟應(yīng)該怎么做呢?
使用for循環(huán)
int[] a = {1,2,3}; int[] b = new int[3]; for(int i = 0; i<a.length; i++) ? ? b[i] = a[i];
這樣可以實(shí)現(xiàn)賦值操作,而且靈活性不錯(cuò),但是效率是個(gè)問(wèn)題。
使用Object的clone()
既然數(shù)組本質(zhì)是對(duì)象,那么他就有clone()方法。我們可以使用clone()方法進(jìn)行復(fù)制:
int[] a={1,2,3}; int[] b=(int[]) a.clone();//別忘了強(qiáng)制類型轉(zhuǎn)換
使用System的靜態(tài)方法arraycopy()
System提供了一個(gè)靜態(tài)方法arraycopy(),原型如下:
public static void arraycopy(Object src, int srcPos, Object dest, int destPos, int length)
src
:源數(shù)組srcPos
:源數(shù)組要復(fù)制的起始位置dest
:目的數(shù)組destPos
:目的數(shù)組放置的起始位置length
:復(fù)制的長(zhǎng)度
我們可以用它來(lái)進(jìn)行數(shù)組之間的復(fù)制:
int[] a ={1,2,3}; int[] b = new int[3]; System.arraycopy(a,0,b,0,3);
這個(gè)方法效率很高,而且具有一定的靈活性。許多基于數(shù)組實(shí)現(xiàn)的Java的集合類底層在數(shù)組復(fù)制的時(shí)候都是使用這個(gè)方法。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
@RequestBody,@RequestParam和@Param的區(qū)別說(shuō)明
這篇文章主要介紹了@RequestBody,@RequestParam和@Param的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03Java實(shí)現(xiàn)員工信息管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)員工信息管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02Spring?Boot的優(yōu)點(diǎn)及項(xiàng)目創(chuàng)建步驟詳解
這篇文章主要介紹了Spring?Boot的優(yōu)點(diǎn)及項(xiàng)目創(chuàng)建步驟,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09java開(kāi)發(fā)hutool HttpUtil網(wǎng)絡(luò)請(qǐng)求工具使用demo
這篇文章主要為大家介紹了hutool之HttpUtil網(wǎng)絡(luò)請(qǐng)求工具使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07深入了解Spring中最常用的11個(gè)擴(kuò)展點(diǎn)
我們一說(shuō)到spring,可能第一個(gè)想到的是?IOC(控制反轉(zhuǎn))?和?AOP(面向切面編程)。除此之外,我們?cè)谑褂胹pring的過(guò)程中,有沒(méi)有發(fā)現(xiàn)它的擴(kuò)展能力非常強(qiáng)。今天就來(lái)跟大家一起聊聊,在Spring中最常用的11個(gè)擴(kuò)展點(diǎn)2022-09-09