java面试题24 关于Java中的数组,
java面試題24 關于Java中的數(shù)組,下面的一些描述,哪些描述是準確的:(????????)
A 數(shù)組是一個對象,不同類型的數(shù)組具有不同的類 B 數(shù)組長度是可以動態(tài)調整的 C 數(shù)組是一個連續(xù)的存儲結構 D:一個固定長度的數(shù)組可類似這樣定義:?int?array[100] E:兩個數(shù)組用equals方法比較時,會逐個便利其中的元素,對每個元素進行比較 F可以二維數(shù)組,且可以有多維數(shù)組,都是在Java中合法的懵逼樹上懵逼果,懵逼樹前你和我
?
數(shù)組的基本概念
如果說現(xiàn)在要求你定義100個整型變量,那么如果按照之前的做法,可能現(xiàn)在定義的的結構如下:
int i1, i2, i3, ... i100;
但是這個時候如果按照此類方式定義就會非常麻煩,因為這些變量彼此之間沒有任何的關聯(lián),也就是說如果現(xiàn)在突然再有一個要求,要求你輸出這100個變量的內容,意味著你要編寫System.out.println()語句100次。
其實所謂的數(shù)組指的就是一組相關類型的變量集合,并且這些變量可以按照統(tǒng)一的方式進行操作。數(shù)組本身屬于引用數(shù)據類型,那么既然是引用數(shù)據類型,這里面實際又會牽扯到內存分配,而數(shù)組的定義語法有如下兩類。
??? 數(shù)組動態(tài)初始化:
??????? 聲明并開辟數(shù)組:
??????????? 數(shù)據類型 [] 數(shù)組名稱 = new 數(shù)據類型[長度];
??????????? 數(shù)據類型 [] 數(shù)組名稱 = new 數(shù)據類型[長度];
??????? 分布進行數(shù)組空間開辟(實例化)
??????? | Tables | Are |
??????? | ------------- |:-------------?
??????? | 聲明數(shù)組: | 數(shù)組類型 數(shù)組名稱[] = null; | | | 數(shù)組類型 [] 數(shù)組名稱 =null; | | 開辟數(shù)組空間: | 數(shù)組名稱 =new` 數(shù)組類型[長度]; |
那么當數(shù)組開辟空間之后,就可以采用如下的方式的操作:
??? 數(shù)組的訪問通過索引完成,即:“數(shù)組名稱[索引]”,但是需要注意的是,數(shù)組的索引從0開始,所以索引的范圍就是0 ~ 數(shù)組長度-1,例如開辟了3個空間的數(shù)組,所以可以使用的索引是:0,1,2,如果此時訪問的時候超過了數(shù)組的索引范圍,會產生java.lang.ArrayIndexOutOfBoundsException 異常信息;
??? 當我們數(shù)組采用動態(tài)初始化開辟空間后,數(shù)組里面的每一個元素都是該數(shù)組對應數(shù)據類型的默認值;
??? 數(shù)組本身是一個有序的集合操作,所以對于數(shù)組的內容操作往往會采用循環(huán)的模式完成,數(shù)組是一個有限的數(shù)據集合,所以應該使用 for 循環(huán)。
??? 在 Java 中提供有一種動態(tài)取得數(shù)組長度的方式:數(shù)組名稱.length;
范例: 定義一個int型數(shù)組
public class ArrayDemo {public static void main(String args[]) {int data[] = new int[3]; /*開辟了一個長度為3的數(shù)組*/data[0] = 10; // 第一個元素data[1] = 20; // 第二個元素data[2] = 30; // 第三個元素for(int x = 0; x < data.length; x++) {System.out.println(data[x]); //通過循環(huán)控制索引}} }數(shù)組本身除了聲明并開辟空間之外還有另外一種開辟模式。
范例: 采用分步的模式開辟數(shù)組空間
public class ArrayDemo {public static void main(String args[]) {int data[] = null;data = new int[3]; /*開辟了一個長度為3的數(shù)組*/data[0] = 10; // 第一個元素data[1] = 20; // 第二個元素data[2] = 30; // 第三個元素for(int x = 0; x < data.length; x++) {System.out.println(data[x]); //通過循環(huán)控制索引}} }但是千萬要記住,數(shù)組屬于引用數(shù)據類型,所以在數(shù)組使用之前一定要開辟控件(實例化),如果使用了沒有開辟空間的數(shù)組,則一定會出現(xiàn) NullPointerException 異常信息:
public class ArrayDemo {public static void main(String args[]) {int data[] = null;System.out.println(data[x]);} }這一原則和之前講解的對象是完全相同的。
數(shù)組在開發(fā)之中一定會使用,但是像上面的操作很少。在以后的實際開發(fā)之中,會更多的使用數(shù)組概念,而直接使用,99%情況下都只是做一個 for 循環(huán)輸出。
數(shù)組引用傳遞
既然數(shù)組屬于引用數(shù)據類型,那么也一定可以發(fā)生引用傳遞。在這之前首先來研究一下數(shù)組的空間開辟。
范例: 觀察一道程序
public class ArrayDemo {public static void main(String args[]) {int data[] = null;data = new int[3]; //開辟一個長度為3的數(shù)組data[0] = 10;data[1] = 20;data[2] = 30;} }??
新建數(shù)組變量
那么既然說到了引用數(shù)據類型了,就一定可以發(fā)生引用傳遞,而現(xiàn)在的引用傳遞的本質也一定是:同一塊堆內存空間可以被不同的棧內存所指向。
范例: 定義一個程序
public class ArrayDemo {public static void main(String args[]) {int data[] = null;data = new int[3]; //開辟一個長度為3的數(shù)組int temp[] = null; //聲明對象data[0] = 10;data[1] = 20;data[2] = 30;temp = data; //int temp[] = data;temp[0] = 99;for(int i = 0; i < temp.length; i++) {System.out.println(data[i]);}} }引用傳遞分析都是一個套路。同一塊堆內存被不同的棧內存所指向。
數(shù)組靜態(tài)初始化
在之前所進行的數(shù)組定義都有一個明顯特點:數(shù)組先開辟內存空間,而后再使用索引進行內容的設置,實際上這種做法都叫做動態(tài)初始化,而如果希望數(shù)組在定義的時候可以同時出現(xiàn)設置內容,那么就可以采用靜態(tài)初始化完成。
數(shù)組的靜態(tài)初始化一共分為以下兩種類型:
Tables ?? ?Are
簡化格式: ?? ?數(shù)據類型 數(shù)組名稱 = {值, 值,…}
完整格式: ?? ?數(shù)據類型 數(shù)組名稱 = new 數(shù)據類型[] {值, 值,…}
范例: 采用靜態(tài)初始化定義數(shù)組
public class ArrayDemo {public static void main(String args[]) {int data[] = {1, 2, 4, 545, 11, 32, 13131, 4444};for(int i = 0; i < data.length; i++) {System.out.println(data[i]);}} }在開發(fā)之中,對于靜態(tài)數(shù)組的初始化強烈建議使用完整語法模式,這樣可以輕松地使用匿名數(shù)組這一概念。
public class ArrayDemo {public static void main(String args[]) {System.out.println(new int[] {1, 2, 4, 545, 11, 32, 13131, 4444}.length);} }以后使用靜態(tài)方式定義數(shù)組的時候一定要寫上完整格式。
數(shù)組最大的缺陷:長度固定。
二維數(shù)組
在之前所使用的數(shù)組發(fā)現(xiàn)只需要一個索引就可以進行訪問,那么這樣的數(shù)組實際上非常像一個數(shù)據行的概念。
現(xiàn)在痛過一個索引就可以取得唯一的一個記錄。所以這樣的數(shù)組可以簡單理解為一維數(shù)組,而二維數(shù)組本質上指的是行列集合,也如果要確定某一個數(shù)據需要行索引和列索引來進行定位。
如果要想確定一個數(shù)據則數(shù)據使用的結構是“數(shù)組名稱[行索引][列索引]”,所以這樣的結構就是一個表的結構。
那么對二維數(shù)組的定義有兩種聲明形式:
??? 數(shù)組的動態(tài)初始化:數(shù)據類型 對象數(shù)組[][] = new 數(shù)據類型[行個數(shù)][列個數(shù)];
??? 數(shù)組的靜態(tài)初始化:數(shù)據類型 對象數(shù)組[][] = new 數(shù)據類型[行個數(shù)][列個數(shù)]{{值, 值,…}, {值, 值,…},…};
數(shù)組的數(shù)組就是二維數(shù)組。
范例: 定義一個二維數(shù)組
public class ArrayDemo {public static void main(String args[]) {//此時的數(shù)組并不是一個等列數(shù)組int data[][] = new int[][] {{1, 2, 3}, {4, 5}, {6, 7, 8, 9}};//如果在進行輸出的時候一定要使用雙重循環(huán),//外部的循環(huán)控制輸出的行數(shù),而內部的循環(huán)控制輸出列數(shù)for(int i = 0; i < data.length; i++) {for(int j = 0; j < data[i].length; j++) {System.out.print("data[" + i + "][" + j + "]=" + data[i][j] + "、");}System.out.println();}} }由于輸出麻煩,所以可以忽略了,在進行開發(fā)之中,出現(xiàn)二位數(shù)組的幾率并不高。
同樣的,我們看看別人的解析,答案最后是
正確答案: A C F
我是歌謠,喜歡敲代碼,無聊刷刷題。不多說了,我先去敲代碼去。有什么不合理之處,歡迎吐槽。
閱讀目錄(置頂)(長期更新計算機領域知識)
閱讀目錄(置頂)(長期更新計算機領域知識)
閱讀目錄(置頂)(長期科技領域知識)
歌謠帶你看java面試題
總結
以上是生活随笔為你收集整理的java面试题24 关于Java中的数组,的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: native2ascii.exe详细使用
- 下一篇: figma下载_Figma的自动版式实用