Java數組的定義與使用方式
一、陣列的基本用法
1.什麼是陣列
陣列:儲存一組相同資料類型的資料的集合。
2.定義數組
int[] :int型別數組
double[] :double類型數組
透過型別就可以定義變量,例如:
int[] array,array就是這個類型的變量,這個變數是儲存一組相同資料的變數。
三種陣列定義的方式:
第一種:
int[] array = {1,2 ,3,4,5,6};
定義一個陣列且初始化
雖然沒寫new,但實際上也是一個物件
注意事項:
int[10] array = {1,2,3,4,5,6};
寫法錯誤,int[] 屬於類型,中括號裡面不能加上任何的數字,相當於在這裡破壞了它的類型。
第二種:
int[] array2 = new int[3];
定義數組未初始化
第三種:
int[] array3 = new int[]{1,2,3,4,5,6};
定義且初始化
三種當中用的最多的就是第一種
3.陣列的使用
取得陣列長度:
Java裡面可以直接透過陣列名稱array.length 求出目前陣列的長度
存取陣列元素:
存取陣列下標為4的元素
越界存取陣列元素:
Java語言越界直接報錯
更改陣列元素:
透過陣列名稱中括號的方式,不只可以存取下標的內容,也可以往下標裡面寫一些資料
列印陣列:
第一種:(for循環)
# 第二種:(增強for迴圈,for each循環)
for迴圈和for each迴圈的差別:
for迴圈是可以拿到下標的,
for each迴圈是拿不到下標的,更多的是用於集合中
第三種:借助Java的操作數組工具類Arrays
二、數組作為方法的參數
基本用法
JVM簡單介紹
# 局部變數在記憶體中的儲存:
引用不指向物件寫法:
這個引用不指向任何的物件
一個引用能不能同時指向多個物件嗎?
對於這個程式碼來說只能指向一個對象,存一個物件的位址。最後只保存了最後一個物件的位址
陣列作為方法的參數傳遞的過程:
求解列印結果:
前兩種求解:
fun2列印結果:
分析範例:下圖代表什麼
代表array2這個引用,指向了array1這個引用所指向的物件。
下圖就代表了上面範例的意思:
#注意事項:
引用指向引用這句話是錯誤的,引用只能指向物件
引用一定在堆疊上嗎?
不一定,一個變數在不在堆疊上,是由你變數的性質決定的,如果你就是一個局部變量,一定是在堆疊上的。如果不是,例如,實例成員變數就不一定是在堆疊上的。
三、陣列練習題
1.交換兩個變數的值
public class TestDemo { public static void swap(int[] array){ int tmp = array[0]; array[0] = array[1]; array[1] = tmp; } public static void main(String[] args) { int[] array = {10,20}; System.out.println("交换前: "+array[0]+" "+array[1]); swap(array); System.out.println("交换后: "+array[0]+" "+array[1]); }
列印結果:
2.寫一個方法, 將陣列中的每個元素都* 2
/** * 在原来的数组上扩大2倍 * @param array */ public static void enlarge(int[] array){ for (int i = 0; i <array.length ; i++) { array[i] = array[i]*2; } } public static void main(String[] args) { int[] array = {1,2,3,4,5,6,7}; enlarge(array); System.out.println(Arrays.toString(array)); }
列印結果:
把原來陣列擴大2倍的值放在一個新的陣列中
/** * 把原来数组扩大2倍的值放在一个新的数组中 * @param array * @return */ public static int[] func(int[] array) { int[] ret = new int[array.length]; for (int i = 0; i < array.length; i++) { ret[i] = array[i] * 2; } return ret; } public static void main(String[] args) { int[] array = {1,2,3,4,5,6,7}; int[] ret = func(array); System.out.println(Arrays.toString(ret)); }
3.模擬實作tostring函數
public static String myToString(int[] array){ String str = "["; for (int i = 0; i <array.length ; i++) { str = str+array[i]; if(i != array.length-1){ str+= ","; } } str= str + "]"; return str; } public static void main(String[] args) { int[] array = {1,2,3,4,5,6,7}; String str = myToString(array); System.out.println(str); }
列印結果:
4.找數組中的最大元素
public static int maxNum(int[] array){ if(array == null) return -1; if (array.length == 0) return -1; int max = array[0]; for (int i = 1; i <array.length ; i++) { if(max < array[i]){ max = array[i]; } } return max; } public static void main(String[] args) { int[] array = {12,8,14,26,5,7,8}; int max = maxNum(array); System.out.println(max); }
列印結果:
#5.找出陣列中指定元素(順序尋找)
public static int findNum(int[] array,int key){ for (int i = 0; i <array.length ; i++) { if(array[i] == key){ return i; } } return -1; } public static void main(String[] args) { int[] array = {2,4,5,6,11,7,8,9}; System.out.println(findNum(array, 7)); }
列印結果:
6.尋找陣列中指定元素(二分查找)
二分查找的必要条件是必须有序的数列 public static int binarySearch(int[] array,int key){ int left = 0; int right = array.length-1; while(left <= right){ int mid = (left+right)/2; if(array[mid] > key){ right = mid - 1; }else if(array[mid] < key){ left = left + 1; }else{ return mid; } } return -1; } public static void main(String[] args) { int[] array = {12,14,15,16,18,23}; System.out.println(binarySearch(array, 15)); }
列印結果:
以上是Java數組的定義與使用方式的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

熱門話題

Java 8引入了Stream API,提供了一種強大且表達力豐富的處理數據集合的方式。然而,使用Stream時,一個常見問題是:如何從forEach操作中中斷或返回? 傳統循環允許提前中斷或返回,但Stream的forEach方法並不直接支持這種方式。本文將解釋原因,並探討在Stream處理系統中實現提前終止的替代方法。 延伸閱讀: Java Stream API改進 理解Stream forEach forEach方法是一個終端操作,它對Stream中的每個元素執行一個操作。它的設計意圖是處
