亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Java數(shù)組的擴(kuò)容代碼示例

 更新時(shí)間:2017年09月26日 10:29:08   作者:Engineer-MrYang  
這篇文章主要介紹了Java數(shù)組的擴(kuò)容,分享了相關(guān)代碼示例,小編覺得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下

本文研究的主要是Java數(shù)組的擴(kuò)容的相關(guān)代碼示例,具體實(shí)現(xiàn)過程如下所示。

在寫程序的過程中,我們常常會(huì)碰見數(shù)組空間不夠用的情況,比如我已經(jīng)初始化了一個(gè)數(shù)組int []a = {1,2,3,4,5,6,7,8,9,10} ;這時(shí),我想往數(shù)組下標(biāo)3的位置插入一個(gè)元素,該怎么做?用C語(yǔ)言實(shí)現(xiàn)太難了吧,需要調(diào)用memcpy函數(shù)要一個(gè)一個(gè)偏,但是在java中就不用那么麻煩了,有種叫數(shù)組的擴(kuò)容方式,輕松實(shí)現(xiàn)。來看看代碼:

public class HelloWorld {
	public static void main(String[] args){
	//	Scanner s = new Scanner(System.in);
	//	System.out.println("請(qǐng)輸入一個(gè)數(shù)字");
	//	int num = s.nextInt();
		//這個(gè)數(shù)組下標(biāo)只能到9
		int []a = {1,2,3,4,5,6,7,8,9,10};
		//先擴(kuò)容
		int []b = Getarray(a,3,100);
		Demoe.PrintArray(b);
	}
	//案例:有一個(gè)數(shù)組已經(jīng)初始化完畢,現(xiàn)向其下標(biāo)3插入一個(gè)元素100
	public static int[] Getarray(int []a , int index , int num){
		int src_array_length = a.length ; 
		int []b = new int[src_array_length+1] ;
		for(int i = 0 ; i < a.length ; i++){
			b[i] = a[i] ; 
		}
		a = b ; //如果還想使用a,使得a指向b
		//接下來從最后一個(gè)元素開始,將最后一個(gè)元素的前面一個(gè)元素拷貝到最后一個(gè)
		//以此類推
		for(int i = a.length - 1 ; i > index ; i--){
			a[i] = a[i-1];
		}
		//別忘了,將要插入的元素插入到對(duì)應(yīng)的數(shù)組坐標(biāo)
		a[index] = num ;
		return a ;
	}
}

也可以使用java中的庫(kù)函數(shù)來實(shí)現(xiàn)

import java.util.Arrays;
public class HelloWorld {
	public static void main(String[] args){
	//	Scanner s = new Scanner(System.in);
	//	System.out.println("請(qǐng)輸入一個(gè)數(shù)字");
	//	int num = s.nextInt();
	int []a = {1,2,3,4,5};
	int []b = new int[a.length] ;
		//1、源數(shù)組
		//2、源數(shù)組的哪個(gè)位置開始
		//3、目標(biāo)數(shù)組
		//4、目標(biāo)數(shù)組的哪個(gè)位置開始存放
		//5、拷貝幾個(gè)
		//System.arraycopy(a, 0, b, 0, a.length);
		//Demoe.PrintArray(b);
		//擴(kuò)容--->擴(kuò)容了一倍
		//a = Arrays.copyOf(a, 2*a.length) ;
		//Demoe.PrintArray(a);
		a = insertArray(a , 3 , 100) ;
		//打印數(shù)組
		System.out.println(Arrays.toString(a));
	}
	//寫一個(gè)函數(shù),向整數(shù)數(shù)組的任意pos位置插入一個(gè)元素value
	public static int[] insertArray(int []a , int pos , int value){
		if(pos < 0 || pos > a.length + 1) //索引下標(biāo)不對(duì),直接返回源數(shù)組 
			return a ;
		//放入一個(gè)元素,先擴(kuò)容,后復(fù)制
		a = Arrays.copyOf(a, a.length+1) ;
		for(int i = a.length - 1 ; i > pos ; i--){
			a[i] = a[i-1] ; //后移動(dòng)
		}
		a[pos] = value ;
		return a ;
	}
}

以上就是數(shù)組擴(kuò)容的Java簡(jiǎn)單實(shí)現(xiàn)代碼,希望對(duì)大家學(xué)習(xí)Java能夠有所幫助。感興趣的朋友可以參閱更多內(nèi)容:Java并發(fā)編程之重入鎖與讀寫鎖 、 淺談java中的局部變量和全局變量 、 淺談Java注解和動(dòng)態(tài)代理等。感謝大家對(duì)本站的支持。

相關(guān)文章

  • java操作ftp下載文件示例

    java操作ftp下載文件示例

    這篇文章主要介紹了java操作ftp下載文件的示例,需要的朋友可以參考下
    2014-02-02
  • 如何利用Spring把元素解析成BeanDefinition對(duì)象

    如何利用Spring把元素解析成BeanDefinition對(duì)象

    這篇文章主要介紹了如何利用Spring把元素解析成BeanDefinition對(duì)象,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08
  • 初次使用IDEA創(chuàng)建maven項(xiàng)目的教程

    初次使用IDEA創(chuàng)建maven項(xiàng)目的教程

    這篇文章主要介紹了初次使用IDEA創(chuàng)建maven項(xiàng)目的教程講解,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2018-01-01
  • Java JVM調(diào)優(yōu)五大技能詳解

    Java JVM調(diào)優(yōu)五大技能詳解

    這篇文章主要為大家介紹了JVM調(diào)優(yōu)的五大技能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • java獲取文件編碼,jsoup獲取html純文本操作

    java獲取文件編碼,jsoup獲取html純文本操作

    這篇文章主要介紹了java獲取文件編碼,jsoup獲取html純文本操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • springboot 如何取消starter的自動(dòng)注入

    springboot 如何取消starter的自動(dòng)注入

    這篇文章主要介紹了springboot 如何取消starter的自動(dòng)注入操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09
  • SpringBoot項(xiàng)目中使用AOP的方法

    SpringBoot項(xiàng)目中使用AOP的方法

    本篇文章主要介紹了SpringBoot項(xiàng)目中使用AOP的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-02-02
  • SpringBoot啟動(dòng)時(shí)加載指定方法的方式小結(jié)

    SpringBoot啟動(dòng)時(shí)加載指定方法的方式小結(jié)

    本文主要給大家介紹了Spring Boot項(xiàng)目啟動(dòng)時(shí)加載指定方法都有哪些方式的,文中給大家介紹了五種常用的方式,有詳細(xì)的代碼示例,具有一定的參考價(jià)值,需要的朋友可以參考下
    2023-08-08
  • Java利用深度搜索解決數(shù)獨(dú)游戲詳解

    Java利用深度搜索解決數(shù)獨(dú)游戲詳解

    數(shù)獨(dú)是一項(xiàng)非常簡(jiǎn)單的任務(wù)。玩家需要根據(jù)9×9盤面上的已知數(shù)字,推理出所有剩余空格的數(shù)字,并滿足每一行、每一列、每一個(gè)粗線宮(3*3)內(nèi)的數(shù)字均含1-9,不重復(fù)。本文將利用Java編寫一個(gè)程序來解決給定的數(shù)獨(dú)任務(wù),感興趣的可以動(dòng)手嘗試一下
    2022-08-08
  • SpringBoot整合Mybatis自定義攔截器不起作用的處理方案

    SpringBoot整合Mybatis自定義攔截器不起作用的處理方案

    這篇文章主要介紹了SpringBoot整合Mybatis自定義攔截器不起作用的處理方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-09-09

最新評(píng)論