數(shù)組在java中的擴容的實例方法
在使用數(shù)組的時候,因為大小的限制,難免會出現(xiàn)不夠用的現(xiàn)象。直接給數(shù)據(jù)對象擴容是不可行的,這時候就需要我們找尋一些其他的方法。本篇先為大家簡單分析擴容的原理,然后創(chuàng)建一個數(shù)組供大家使用,最后提供兩種數(shù)組擴容方法:for循環(huán)和Arrays,下面一起來看具體的操作。
1.擴容的原理
(1)Java數(shù)組對象的大小是固定不變的,數(shù)組對象是不可擴容的。
(2)利用數(shù)組復制方法可以變通的實現(xiàn)數(shù)組擴容。
(3)System.arraycopy()可以復制數(shù)組。
(4)Arrays.copyOf()可以簡便的創(chuàng)建數(shù)組副本。
(5)創(chuàng)建數(shù)組副本的同時將數(shù)組長度增加就變通的實現(xiàn)了數(shù)組的擴容。
2.先創(chuàng)建數(shù)組
import java.util.Arrays;
//數(shù)組的擴容示例
public class Test {
public static void main(String [] args){
//創(chuàng)建一個原始數(shù)組,并做好初始化。
// int [] arry = {1,3,5,7,9};
int arry[] =new int[]{1,3,5,7,9};
int arry1[]=new int[7];//新建一個新數(shù)組這里的7=arry.length+需要擴容的長度
System.out.println("打印原始數(shù)組的長度為:"+arry.length);
System.out.println("打印新數(shù)組的長度為:"+arry1.length);
//驗證該數(shù)組有沒有創(chuàng)建完成,可以獲取一下數(shù)組元素看看能不能成功。
// System.out.println(arry[1]);
//把從舊數(shù)組中獲取的數(shù)據(jù)一個一個的存到新的數(shù)組里面去,并新增兩個數(shù):11,13。
//如何把數(shù)據(jù)存到數(shù)組里面去,使用arry1[0]=1;
/*
3.方法一:循環(huán)遍歷原始數(shù)組arry,長度是固定的,所以用for循環(huán)。
//1、先完成復制數(shù)組
for(int i=0;i<arry.length;i++){
arry1[i] = arry[i];
}
//2、再完成賦值插入操作,即已完成數(shù)組的擴容操作。
arry1[5]=11;
arry1[6]=13;
System.out.println("新數(shù)組為:"+arry1[5]);
System.out.println("新數(shù)組為:"+arry1[6]);
*/
/*
4.方法二:使用java的util包的Arrays類的copyOf(原數(shù)組名,新數(shù)組長度)方法來進行復制。
arry1 = Arrays.copyOf(arry,arry.length+2);
arry1[5] = 11;
arry1[6] = 13;
System.out.println("新數(shù)組為:"+arry1[5]);
System.out.println("新數(shù)組為:"+arry1[6]);
以上就是數(shù)組在java中的擴容方法,這兩種方法相對新手而言,是非常容易實現(xiàn)擴容的。
相關實例擴展:
import java.util.Arrays;
public class HelloWorld {
public static void main(String[] args){
// Scanner s = new Scanner(System.in);
// System.out.println("請輸入一個數(shù)字");
// int num = s.nextInt();
int []a = {1,2,3,4,5};
int []b = new int[a.length] ;
//1、源數(shù)組
//2、源數(shù)組的哪個位置開始
//3、目標數(shù)組
//4、目標數(shù)組的哪個位置開始存放
//5、拷貝幾個
//System.arraycopy(a, 0, b, 0, a.length);
//Demoe.PrintArray(b);
//擴容--->擴容了一倍
//a = Arrays.copyOf(a, 2*a.length) ;
//Demoe.PrintArray(a);
a = insertArray(a , 3 , 100) ;
//打印數(shù)組
System.out.println(Arrays.toString(a));
}
//寫一個函數(shù),向整數(shù)數(shù)組的任意pos位置插入一個元素value
public static int[] insertArray(int []a , int pos , int value){
if(pos < 0 || pos > a.length + 1) //索引下標不對,直接返回源數(shù)組
return a ;
//放入一個元素,先擴容,后復制
a = Arrays.copyOf(a, a.length+1) ;
for(int i = a.length - 1 ; i > pos ; i--){
a[i] = a[i-1] ; //后移動
}
a[pos] = value ;
return a ;
}
}
到此這篇關于數(shù)組在java中的擴容的實例方法的文章就介紹到這了,更多相關數(shù)組在java中的擴容方法淺析內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
spring?boot只需兩步優(yōu)雅整合activiti示例解析
這篇文章主要主要來教大家spring?boot優(yōu)雅整合activiti只需兩步就可完成測操作示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助祝大家多多進步2022-03-03
解決springboot啟動失敗的問題('hibernate.dialect'?not?set)
這篇文章主要介紹了解決springboot啟動失敗的問題('hibernate.dialect'?not?set),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12
在Spring中利用@Order注解對bean和依賴進行排序
在Spring框架中,@Order是一個經常被忽視但非常重要的注解,在項目開發(fā)中,當我們需要維護bean的特定順序或者存在許多相同類型的bean時,這個注解就發(fā)揮了作用,這篇文章講的就是如何利用@Order注解對bean和依賴進行排序,需要的朋友可以參考下2023-11-11
RocketMQ?ConsumeQueue與IndexFile實時更新機制源碼解析
這篇文章主要為大家介紹了RocketMQ?ConsumeQueue與IndexFile實時更新機制源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-05-05

