當前位置 : IT培訓網 > Java開發 > Java教程 > Java數組的定義和內存分配

Java數組的定義和內存分配

時間:2016-08-03 15:46:27??來源:Java培訓網??作者:IT培訓網??已有:名學員訪問該課程
標簽(Tag):?? java(710)java數組(8)
type 為Java中的任意數據類型,包括基本類型和組合類型,arrayName為數組名,必須是一個合法的標識符,[ ] 指明該變量是一個數組類型變量。

數組在我們學習數學時經常用到,那么這里的數組講的是什么呢,今天就讓達內小編來給大家詳細介紹下吧。

如果希望保存一組有相同類型的數據,可以使用數組。

數組的定義和內存分配

Java 中定義數組的語法有兩種:

    type arrayName[];

    type[] arrayName;

type 為Java中的任意數據類型,包括基本類型和組合類型,arrayName為數組名,必須是一個合法的標識符,[ ] 指明該變量是一個數組類型變量。例如:

int demoArray[];

int[] demoArray;

這兩種形式沒有區別,使用效果完全一樣,讀者可根據自己的編程習慣選擇。

 

與C、C++不同,Java在定義數組時并不為數組元素分配內存,因此[ ]中無需指定數組元素的個數,即數組長度。而且對于如上定義的一個數組是不能訪問它的任何元素的,我們必須要為它分配內存空間,這時要用到運算符new,其格式如下:

    arrayName=new type[arraySize];

其中,arraySize 為數組的長度,type 為數組的類型。如:

demoArray=new int[3];

為一個整型數組分配3個int 型整數所占據的內存空間。

 

通常,你可以在定義的同時分配空間,語法為:

    type arrayName[] = new type[arraySize];

例如:

int demoArray[] = new int[3];

數組的初始化

 

你可以在聲明數組的同時進行初始化(靜態初始化),也可以在聲明以后進行初始化(動態初始化)。例如:

// 靜態初始化

// 靜態初始化的同時就為數組元素分配空間并賦值

int intArray[] = {1,2,3,4};

String stringArray[] = {"微學苑", "http://www.weixueyuan.net", "一切編程語言都是紙老虎"};

 

// 動態初始化

float floatArray[] = new float[3];

floatArray[0] = 1.0f;

floatArray[1] = 132.63f;

floatArray[2] = 100F;

數組引用

 

可以通過下標來引用數組:

    arrayName[index];

與C、C++不同,Java對數組元素要進行越界檢查以保證安全性。

 

每個數組都有一個length屬性來指明它的長度,例如 intArray.length 指明數組 intArray 的長度。

 

【示例】寫一段代碼,要求輸入任意5個整數,輸出它們的和。

import java.util.*;

public class Demo {

    public static void main(String[] args){

        int intArray[] = new int[5];

        long total = 0;

        int len = intArray.length;

      

        // 給數組元素賦值

        System.out.print("請輸入" + len + "個整數,以空格為分隔:");

        Scanner sc = new Scanner(System.in);

        for(int i=0; i<len; i++){

            intArray[i] = sc.nextInt();

        }

      

        // 計算數組元素的和

        for(int i=0; i<len; i++){

            total += intArray[i];

        }

      

        System.out.println("所有數組元素的和為:" + total);

    }

}

運行結果:

請輸入5個整數,以空格為分隔:10 20 15 25 50

所有數組元素的和為:120

數組的遍歷

 

實際開發中,經常需要遍歷數組以獲取數組中的每一個元素。最容易想到的方法是for循環,例如:

int arrayDemo[] = {1, 2, 4, 7, 9, 192, 100};

for(int i=0,len=arrayDemo.length; i<len; i++){

    System.out.println(arrayDemo[i] + ", ");

}

輸出結果:

1, 2, 4, 7, 9, 192, 100,

 

不過,Java提供了”增強版“的for循環,專門用來遍歷數組,語法為:

for( arrayType varName: arrayName ){

    // Some Code

}

arrayType 為數組類型(也是數組元素的類型);varName 是用來保存當前元素的變量,每次循環它的值都會改變;arrayName 為數組名稱。

 

每循環一次,就會獲取數組中下一個元素的值,保存到 varName 變量,直到數組結束。即,第一次循環 varName 的值為第0個元素,第二次循環為第1個元素......例如:

int arrayDemo[] = {1, 2, 4, 7, 9, 192, 100};

for(int x: arrayDemo){

    System.out.println(x + ", ");

}

輸出結果與上面相同。

 

這種增強版的for循環也被稱為”foreach循環“,它是普通for循環語句的特殊簡化版。所有的foreach循環都可以被改寫成for循環。

 

但是,如果你希望使用數組的索引,那么增強版的 for 循環無法做到。

二維數組

 

二維數組的聲明、初始化和引用與一維數組相似:

int intArray[ ][ ] = { {1,2}, {2,3}, {4,5} };

int a[ ][ ] = new int[2][3];

a[0][0] = 12;

a[0][1] = 34;

// ......

a[1][2] = 93;

Java語言中,由于把二維數組看作是數組的數組,數組空間不是連續分配的,所以不要求二維數組每一維的大小相同。例如:

int intArray[ ][ ] = { {1,2}, {2,3}, {3,4,5} };

int a[ ][ ] = new int[2][ ];

a[0] = new int[3];

a[1] = new int[5];

 

【示例】通過二維數組計算兩個矩陣的乘積。

public class Demo {

    public static void main(String[] args){

        // 第一個矩陣(動態初始化一個二維數組)

        int a[][] = new int[2][3];

        // 第二個矩陣(靜態初始化一個二維數組)

        int b[][] = { {1,5,2,8}, {5,9,10,-3}, {2,7,-5,-18} };

        // 結果矩陣

        int c[][] = new int[2][4];

      

        // 初始化第一個矩陣

        for(int i=0; i<2; i++)

            for(int j=0; j<3 ;j++)

                a[i][j] = (i+1) * (j+2);

      

        // 計算矩陣乘積

        for (int i=0; i<2; i++){

            for (int j=0; j<4; j++){

                c[i][j]=0;

                for(int k=0; k<3; k++)

                    c[i][j] += a[i][k] * b[k][j];

            }

        }

 

        // 輸出結算結果

        for(int i=0; i<2; i++){

            for (int j=0; j<4; j++)

                System.out.printf("%-5d", c[i][j]);

            System.out.println();

        }

    }

}

運行結果:

25   65   14   -65

50   130  28   -130

 

幾點說明:

上面講的是靜態數組。靜態數組一旦被聲明,它的容量就固定了,不容改變。所以在聲明數組時,一定要考慮數組的最大容量,防止容量不夠的現象。

如果想在運行程序時改變容量,就需要用到數組列表(ArrayList,也稱動態數組)或向量(Vector)。

正是由于靜態數組容量固定的缺點,實際開發中使用頻率不高,被 ArrayList 或 Vector 代替,因為實際開發中經常需要向數組中添加或刪除元素,而它的容量不好預估。

頂一下
(0)
0%
踩一下
(0)
0%
------分隔線----------------------------
------分隔線----------------------------
Java教程
1、Java 概述
1.1 Java語言概述
1.2 Java虛擬機以及跨平臺原理
1.3 Java的主要就業方向
1.4 Java的不同版本
1.5 Java開發環境搭建
1.6 第一個Java程序示例
1.7 Java類和對象的概念
1.8 Java類庫及其組織結構
1.9 Java import
2、Java 語法基礎
2.1 Java數據類型以及變量的定義
2.2 Java數據類型轉換
2.3 Java運算符
2.4 Java流程控制
2.5 Java數組的定義和使用
2.6 Java字符串(String)
2.7 Java StringBuffer與StringBuider
2.8 強調一下編程風格
3、Java 類與對象
3.1 Java類的定義及其實例化
3.2 Java訪問修飾符
3.3 Java變量的作用域
3.4 Java this關鍵字詳解
3.5 Java方法重載
3.6 Java類的基本運行順序
3.7 Java包裝類、拆箱和裝箱詳解
3.8 再談Java包
3.9 源文件的聲明規則
4、Java 繼承和多態
4.1 繼承的概念與實現
4.2 Java super關鍵字
4.3 繼承中的方法的覆蓋和重載
4.4 多態和動態綁定
4.5 instanceof 運算符
4.6 多態對象的類型轉換
4.7 Java static關鍵字
4.8 Java final關鍵字
4.9 Java Object類
5、面向對象高級特性
5.1 Java內部類及其實例化
5.2 內部類的分類
5.3 抽象類的概念和使用
5.4 接口的概念和使用
5.5 接口和抽象類的區別
5.6 Java 泛型
5.7 泛型通配符和類型參數的范圍
6、異常處理
6.1 異常處理基礎
6.2 異常類型Java語言中常見的異常類型有哪些
6.3 未被捕獲的異常
6.4 try和catch的使用
6.5 多重catch語句的使用
6.6 try語句的嵌套
6.7 throw:異常的拋出
6.8 throws子句
6.9 finally塊
6.10 Java的內置異常
6.11 創建自己的異常子類
6.12 斷言
7、線程編程
7.1 線程的概念
7.2 Java線程模型
7.3 主線程
7.4 創建線程
7.5 創建多線程
7.6 isAlive()和join()的使用
7.7 線程優先級
7.8 線程同步
7.9 線程間通信
7.10 線程死鎖
7.11 線程的掛起、恢復和終止
8、輸入輸出(IO)操作
8.1 輸入輸出基本概念
8.2 面向字符的輸入流
8.3 面向字符的輸出流
8.4 面向字節的輸入輸出流
8.5 面向字節流的應用
8.6 文件與目錄管理
8.7 文件的隨機讀寫
8.8 文件的壓縮處理
9、常用類庫、向量與哈希
9.1 Java基礎類庫
9.2 Object類
9.3 Java語言包(java.lang)簡介
9.4 日期和時間類
9.5 向量及其應用
9.6 哈希表及其應用
10、圖形界面(GUI)設計
10.1 圖形界面設計基礎
10.2 框架窗口
10.3 標簽、按鈕和按鈕事件
10.4 面板
10.5 布局設計
10.6 文本框和文本區
10.7 文本框和文本區的輸入輸出
10.8 選擇框和單選按鈕
10.9 列表和組合框
10.10 菜單
10.11 對話框
10.12 滾動條
10.13 鼠標事件
10.14 鍵盤事件
11、圖形、圖像與多媒體
11.1 繪圖基礎
11.2 設置字型和顏色
11.3 繪圖模式
11.4 Graphics類的繪圖方法
11.5 Graphics2D類的繪圖方法
11.6 圖像處理基礎
11.7 圖像緩沖技術
11.8 多媒體基礎
12、網絡與數據庫編程
12.1 IP地址和InetAddress類
12.2 統一資源定位符
12.3 套接字(Socket)
12.4 數據庫連接
12.5 幾個重要的類和接口
12.6 數據庫查詢
12.7 數據庫更新
12.8 插入記錄
12.9 修改記錄
12.10 刪除記錄
激情色播