Rumah > Java > javaTutorial > Array ringkasan pembelajaran Java (tersusun dan dikongsi)

Array ringkasan pembelajaran Java (tersusun dan dikongsi)

WBOY
Lepaskan: 2022-04-01 12:01:33
ke hadapan
2672 orang telah melayarinya

Artikel ini membawa anda pengetahuan yang berkaitan tentang java, yang terutamanya memperkenalkan isu yang berkaitan dengan tatasusunan, termasuk sebab untuk menggunakan tatasusunan, takrif tatasusunan, permulaan tatasusunan dan fungsi tatasusunan , dsb. Saya harap ia akan membantu semua orang.

Array ringkasan pembelajaran Java (tersusun dan dikongsi)

Kajian yang disyorkan: "tutorial java"

1. Mengapa menggunakan tatasusunan dan takrifan tatasusunan

1.1 Mengapa menggunakan tatasusunan

Soalan 1:

Apabila mengisytiharkan pembolehubah, setiap pembolehubah individu mesti sepadan dengan nama pembolehubah, tetapi kini apabila kumpulan data daripada jenis yang sama akan diproses, Jika anda ingin mewakili umur 100 orang dalam kelas, dan anda pasti tidak mahu menentukan 100 pembolehubah untuk mewakili umur semua orang, apakah yang perlu anda lakukan? Pertimbangkan contoh berikut sekali lagi.

umur int = 17;//Menunjukkan umur

Soalan 2:

Untuk mencari hasil tambah dua nombor, anda memerlukan kaedah Untuk mencari hasil tambah 5 nombor, anda memerlukan Overload kaedah untuk mencari jumlah 100 nombor, jumlah 1000 nombor, dan jumlah 10000 nombor Senarai parameter kaedah akan menjadi sangat panjang, dan akan ada banyak kaedah, dan anda akan mempunyai untuk mengingati kaedah yang mana Kaedah yang mempunyai dua parameter dan kaedah yang mempunyai tiga parameter. Ini sentiasa terasa sangat tidak menyenangkan Jika anda menganalisis fungsi ini dengan teliti, ia sebenarnya hanya untuk mencari jumlah set nilai Kaedah ini tidak mengambil berat tentang bilangan tambahan, ia hanya mengambil berat tentang nombor yang perlu ditambah.

Cadangan Sarjana: Apabila mentakrifkan parameter formal kaedah, sebaiknya tidak melebihi 5.

1.2 Apakah itu tatasusunan

Ringkasnya, ia adalah satu set data, longgokan data. Tatasusunan yang dipanggil ialah borang data di mana beberapa pembolehubah daripada jenis yang sama disusun dengan teratur untuk kemudahan pemprosesan dalam pengaturcaraan. Koleksi data ini daripada jenis yang sama disusun dalam susunan tertentu dipanggil tatasusunan . Setiap data dalam tatasusunan dipanggil elemen tatasusunan Unsur-unsur dalam tatasusunan diindeks untuk menunjukkan lokasi storannya Indeks bermula dari 0 dan saiz langkah ialah 1. Ia sedikit seperti nombor baris baris yang meningkat. mengikut baris.

1.3 Definisi tatasusunan

Kaedah 1 (

disyorkan untuk menggunakan ): Jenis elemen tatasusunan [ ] Nama tatasusunan; cth: int[] umur; Anda boleh menganggap int[] sebagai jenis data, jenis tatasusunan jenis int.

Kaedah 2:

Jenis elemen tatasusunan Nama tatasusunan[]; cth: int umur[];Nota:

Tatasusunan mesti dimulakan sebelum ia boleh digunakan. Kerana permulaan bermakna memperuntukkan ruang dalam ingatan. 2. Permulaan tatasusunan

Tatasusunan dalam Java mesti dimulakan sebelum boleh digunakan

Apa yang dipanggil inisialisasi adalah untuk memperuntukkan memori kepada tatasusunan elemen dan berikan memori kepada setiap elemen.  Dua cara untuk memulakan tatasusunan dibahagikan kepada

pemulaan statik

, pemulaan dinamik; dimulakanSetelah pemulaan selesai, panjang tatasusunan ditetapkan melainkan dimulakan semula. Dalam erti kata lain, tatasusunan ialah panjang tetap . Tatasusunan mempunyai panjang tetap: Setelah tatasusunan berjaya dimulakan, bilangan elemen dalam tatasusunan ditetapkan dan tidak boleh diubah. Jika anda perlu menukarnya, anda hanya boleh memulakannya semula.

2.1 Permulaan statik tatasusunan Terpulang kepada kita untuk menetapkan nilai permulaan bagi setiap elemen tatasusunan, dan panjang tatasusunan ditentukan oleh sistem (JVM).

Sintaks:

Jenis elemen tatasusunan [] Nama tatasusunan =

baharu Jenis elemen tatasusunan []{elemen 1, elemen 2, elemen 3,....};Contoh:

int[] nombor = baharu int[]{1,3,5,7,9};

Kaedah penulisan mudah, mesti dimulakan serta-merta selepas pengisytiharan, tidak boleh diisytiharkan dahulu dan kemudian dimulakan int[] nums = {1,3,5,7,9};

Ilustrasi pemulaan statik dan penugasan semula tatasusunan

2.2 Permulaan dinamik tatasusunan

Kami tetapkan naik tatasusunan Bilangan elemen (panjang tatasusunan) , dan nilai awal setiap elemen tatasusunan ditentukan oleh sistem.

Sintaks:

Jenis elemen tatasusunan [] Nama tatasusunan = jenis unsur Tatasusunan baharu [ panjang ];

Contoh:

    int[] ages = new  int[
100
];
Salin selepas log masuk

Nota: int[] nums = baharu int[5]{1,3, 5,7,9};//Tulisan salah. Pemulaan statik dan pemulaan dinamik tidak boleh digunakan pada masa yang sama.

2.3 Bila hendak menggunakan pemula statik dan bila hendak menggunakan pemula dinamik?

Apabila kami mengetahui terlebih dahulu data apa yang perlu disimpan , pilih pemulaan statik ; 🎜>Apabila kami

tidak tahu terlebih dahulu data apa yang perlu disimpan , kami hanya boleh menggunakan pemulaan dinamik ; > >Java menetapkan nilai awal untuk jenis data, seperti ditunjukkan di bawah:

Jenis data

数据类型

初始值

byte、short、int

0

long

0L

float

0F

double

0.0D

boolean

false

char

’u0000‘ (表示空)

引用数据类型

null

<🎜><🎜>Nilai awal<🎜><🎜>
<🎜><🎜> bait, pendek, int<🎜><🎜><🎜>0<🎜>
<🎜><🎜>panjang<🎜>< 🎜><🎜>0L<🎜>
<🎜><🎜>terapung<🎜><🎜> <🎜>0F <🎜>
<🎜><🎜>ganda<🎜><🎜><🎜>0.0D<🎜>< /td>< /tr>
<🎜><🎜>boolean<🎜><🎜><🎜>false<🎜>
<🎜><🎜>char<🎜><🎜><🎜>'u0000' (menandakan kosong) <🎜>
<🎜> <🎜>Jenis data rujukan<🎜><🎜><🎜>null<🎜>

三、数组基本操作(一维数组)

3.1 数组基本操作:

  • 获取元素: 元素类型 变量 = 数组名[index];
  • 设置元素: 数组名[index] = 值;
  • 遍历数组元素: 建议使用for循环,因为for循环事先知道循环的次数
  • 数组长度: int len = 数组名.length; length是属性,不是方法.
  • 索引范围: 从0开始,逐一递增。 [0,数组名.length-1]

3.2 操作数组常见异常:

NullPointerException:空指针异常(空引用)。

出现该异常的原因:当数组还未初始化,就直接操作数组

如以下代码:

String[] bs = null;

System.out.println(bs.length)
Salin selepas log masuk

ArrayIndexOutOfBoundsException:数组的索引越界异常。

出现该异常的原因:根据索引取出数据元素时,输入了超出数组索引范围之外的值。

如下代码:

int[] nums = {1,3,5,7,9};

int a = nums[4];
Salin selepas log masuk

3.3 获取数组最大最小元素

/**
 * 求数组最大值
 *
 * @param nums
 * @return
 */
public static int getMax(int[] nums) {
    int result = 0;
    for (int i = 0; i < nums.length; i++) {
        int num = nums[i];
        if (result < num) {
            result = num;
        }
    }
    return result;
}

/**
 * 求数据最小值
 *
 * @param nums
 * @return
 */
public static int getMin(int[] nums) {
    int result = 0;
    for (int i = 0; i < nums.length; i++) {
        int num = nums[i];
        if (i == 0) {
            result = num;
        }
        if (result > num) {
            result = num;
        }
    }
    return result;
}
Salin selepas log masuk

3.4 打印数组元素

当我们直接使用System.out.println()打印数组的时候,打印出来是hashCode值,如

int[] nums = new int[]{1, 3, 5, 7, 9};

System.out.println(nums);
Salin selepas log masuk

我们不喜欢,我们想打印数组的时候,把该数组的元素打印出来,这时需要循环遍历打印

int[] nums = new int[]{1, 3, 5, 7, 9};
for (int i = 0; i < nums.length; i++) {
    System.out.print(nums[i] + " ");
}
Salin selepas log masuk

但是呢,每次想打印数据中的元素都还要循环遍历一遍,好麻烦啊! 有没有更好的方式呢?其实不用着急,Java前辈们已经帮我们想到了这一点了,我们只需要调用Arrays.toString()方法就能够对数组进行打印

3.5 逆序排列数组元素

例子:原数组[A, B, C, D, E],要求对该数组进行逆序操作得到新数组:[E, D, C, B, A]。

public static String[] reversedOrder(String[] nums) {
    String[] result = new String[nums.length];
    int index = 0;
    for (int i = nums.length - 1; i >= 0; i--) {
        result[index] = nums[i];
        index++;
    }
    return result;
}
Salin selepas log masuk

3.6 线性搜索:元素出现索引(第一次/最后一次)

数组的线性搜索指得就是挨个遍历,查找数组中与key相同的元素,若查找不到则可以返回-1(惯例,自定义),其效率为O(n)。

例子:int[] arr = {10,20,30,10,50,-30,10};获取元素10在arr数组中第一次出现的索引和最后一次出现的索引

/**
 * 获取数组中指定元素第一次出现的索引
 *
 * @param nums
 * @param element
 * @return
 */
public static int indexOf(int[] nums, int element) {
    for (int i = 0; i < nums.length; i++) {
        if (element == nums[i]) {
            return i;
        }
    }
    return -1;
}

/**
 * 获取数组中指定元素最后一次出现的索引
 *
 * @param nums
 * @param element
 * @return
 */
public static int lastIndexOf(int[] nums, int element) {
    for (int i = nums.length - 1; i >= 0; i--) {
        if (element == nums[i]) {
            return i;
        }
    }
    return -1;
}
Salin selepas log masuk

四、多维数组

在前面的文章中我们有提到数组其实就是是多个数据的集合。如果现在有多个数组,我想把多个数组保存在一个集合中,此时我又应该如何完成呢?此时就需要引入多维数组的概念。多维数组其实就是把整个数组看成一个元素,存放到另一个数组当中去

多维数组的语法:

数组元素类型[] 数组名;

例如如下定义二维数组的格式

int[][]  arr = new int[][]   {

  arr1 ,arr2,arr3

};

int[][]  arr = new int[][]   {

  {1,2,3} ,

  {4,5},

  {6}

};
Salin selepas log masuk

4.1 多维数组和一维数组的区别

  • 一维数组:数组中的每一个元素都是一个值(基本类型和引用类型的值);
  • 二维数组:数组中的每一个元素又是一个一位数组;
  • 三维数组:数组中的每一个元素又是一个二维数组;

注意:严格上说在Java中不存在多维数组的概念。为了和C语言做区分一般称之为数组中的数组

4.2 二维数组的初始化操作

静态初始化

int[][] arr = new int[][] {

{1,2,3} ,

{4,5},

{6}

};

动态初始化

int[][] arr = new int[3][5] ;//创建一个长度为3的二维数组,每一个元素(一维数组)的长度为5。

针对于N维数组,需要N个循环嵌套。

五、Java5对数组的新语法支持

Java5对数组的新语法支持主要是增强for循环(foreach)方法的可变参数

5.1 增强for循环-foreach

在之前我们使用for循环的打印元素操作如下

int[] nums = new int[]{1, 3, 5, 7, 9};
for (int i = 0; i < nums.length; i++) {
    System.out.println(nums[i]);
}
Salin selepas log masuk

其实我们在使用循环迭代数组的时候,往往是不关心迭代变量(数组的索引)。那在Java中有没有更好的方式,在迭代数组元素的时候就只操作数组元素,不去操作数组的索引呢?其实是有的。

从Java5开始(JDK1.5)开始,Java提供了一种新的语法:增强for循环(foreach)。

语法:

for(数组元素类型 变量 : 数组名)

{

循环体

}

我们通过反编译工具查看字节码,会发现foreach其实在底层依然是使用for循环+索引来操作数组的。我们把增强for循环称之为编译器的新特性---->语法糖

注意:语法糖的最大甜头就是让开发者写更少、更简单的代码,完成相同的功能。当我们在迭代数组元素的时候不关心数组的索引的时,首选使用foreach。当然咯,foreach远远没有本篇博客讲解的这么简单,星仔到时候带着大家在集合框架篇的时候再深入讲解foreach。

5.2 方法的可变参数

Java5的时候为什么要增加可变参数呢?我们来看一下以下的需求

需求:编写一个方法,统计使用数组传递过来的总和。

虽然说也是可以实现,但是我们心里肯定是不爽的,主要在于以下几点:

  • 为了求多个数之和,我们还得先创建一个数组来存储数据。
  • 如果多个数是变化的,比如求3个数之和变成求5个数之和.......,还得去修改定义数组,但是数组是定长的。

那如果要解决该问题该怎么办呢?这个时候就需要引入Java5的另一个新特性:方法的可变参数(说的是参数的个数可变)

注意:

  • 方法的可变参数其实也是一个语法糖,是编译器级别的新特性。主要是为了让开发者写代码更简单。
  • 方法的可变参数其底层是就是一个数组类型
  • 可变参数必须作为方法的最后一个参数,避免参数的歧义性。
  • 一个方法最多只有一个可变参数

六、数组元素拷贝

数组拷贝:从指定源数组中复制一个数组,复制从指定的位置开始,到目标数组的指定位置结束。

  • 从 src 引用的源数组到 dest 引用的目标数组,数组组件的一个子序列被复制下来。
  • 被复制的组件的编号等于 length 参数。
  • 源数组中位置在 srcPos 到 srcPos+length-1 之间的组件被分别复制到目标数组中的 destPos 到 destPos+length-1 位置。

数组拷贝操作是经常使用到的,SUN就直接把数组的拷贝操作存放在JDK中的System类中

Object:Java语言中的根类。是所有类的老祖宗。Object可以表示任意数据类型。

该方法没有方法体,该方法使用了native修饰符(本地方法)。该方法底层使用了C/C++语言实现了,Java直接调用其他语言编写好的功能

arraycopy 方法使用方式

System.arraycopy(src, 2, dest, 5, 4);
Salin selepas log masuk

查阅API文档了(Java的帮助文档/好比字典),在什么类中有什么功能的方法即可。文档在手,天下我有!

推荐学习:《java学习教程

Atas ialah kandungan terperinci Array ringkasan pembelajaran Java (tersusun dan dikongsi). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:csdn.net
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan