初始化
- 静态初始化
所谓静态初始化,就是在定义数组的同时将其初始化;
int[] arr1 = {1, 3, 5, 8, 10};
int[] arr2 = new int[] {1, 3, 5, 8, 10};
- 动态初始化
动态初始化,就是先声明数组定义之后,再对其进行赋值;
int[] arr = new int[5];
arr[0] = 1;
arr[1] = 3;
arr[2] = 5;
arr[3] = 8;
arr[4] = 10;
PS:注意数组的索引位置不能超过数组的长度,如上面例子中的数组长度为 5
,所以我们数组的索引位置最大只能为 4
,否则就会报数组越界错误。
求数组长度
求数组的长度,利用数组的 length
属性即可;
int[] arr = new int[10];
int size = arr.length; // 10
System.out.println("size = " + size);
二维数组
初始化
- 静态初始化
int[][] arr1 = {{1, 2, 4}, {5, 7, 9}, {19, 12, 18}};
- 动态初始化
二位数组动态声明时,一种是把行和列的长度都指定,而另一种是只需要指定行的长度,不用指定列的长度,列的长度会在初始化时自动确认。
int[][] arr1= new int[3][3];
arr1 = new int[][]{{1, 2, 4}, {5, 7, 9}, {19, 12, 18}};
int[][] arr2= new int[3][];
arr2 = new int[][]{{1, 2, 4}, {5, 7, 9}, {19, 12, 18}};
求数组长度
不同于一维数组,因为二维数组有行和列,所需求长度时需要分别求。
int[][] arr = new int[10][20];
// 求行的长度
int row = arr.lenght;
// 求列的长度,此时求任意一行所在的列的长度即可
int col = arr[0].length;
既然我们已经学会了数组的声明及初始化,接下来就是对数组进行操作,而最常见的则是遍历数组。
假设我们有一个数组如下:
String[] arr = new String[5];
arr = new String[]{“村雨遥”, “海贼王”, “进击的巨人”, “鬼灭之刃”, “斗罗大陆”};
标准 for 循环
首先,我们来使用标准的 for
循环来遍历该数组,只需要通过数组的索引位置来访问即可。
/**
-
@author : cunyu
-
@version : 1.0
-
@className : TraverseTest
-
@date : 2021/4/25 11:52
-
@description : 遍历
*/
public class TraverseTest {
public static void main(String[] args) {
String[] arr = new String[5];
arr = new String[]{“村雨遥”, “海贼王”, “进击的巨人”, “鬼灭之刃”, “斗罗大陆”};
// 数组长度
int size = arr.length;
for (int i = 0; i < size; i++) {
System.out.println(“第 " + (i + 1) + " 个元素:” + arr[i]);
}
}
}
增强 for 循环
/**
-
@author : cunyu
-
@version : 1.0
-
@className : EnforceTraverseTest
-
@date : 2021/4/26 9:14
-
@description : 增强 for 循环
*/
public class EnforceTraverseTest {
public static void main(String[] args) {
String[] arr = new String[5];
arr = new String[]{“村雨遥”, “海贼王”, “进击的巨人”, “鬼灭之刃”, “斗罗大陆”};
int index = 0;
for (String name : arr) {
System.out.println(“第 " + (index + 1) + " 个元素:” + name);
index++;
}
}
}
两者的区别:标准 for
循环是通过计数器来进行遍历,我们能够很清晰的得知每个元素所对应的索引位置,而增强 for each
循环则是直接访问数组中的元素值,而不关心每个元素对应的索引位置。
标准库遍历
通过调用标准库 Arrays
中的 toString()
方法,我们可以将任意类型的数组转换为一个字符串表示形式,从而打印出来。
import java.util.Arrays;
/**
-
@author : cunyu
-
@version : 1.0
-
@className : StandardLibraryTest
-
@date : 2021/4/26 9:22
-
@description : 标准库遍历
*/
public class StandardLibraryTest {
public static void main(String[] args) {
String[] arr = new String[5];
arr = new String[]{“村雨遥”, “海贼王”, “进击的巨人”, “鬼灭之刃”, “斗罗大陆”};
System.out.println(Arrays.toString(arr));
}
}
以上的遍历主要是针对一维数组,而针对二维数组,当我们要访问其中的一个元素时,可以使用 array[row][col]
来进行访问,而对于二维及更多维的数组,可以使用 Arrays.deepToString()
。
使用排序算法
排序算法多样,最常用的则有 冒泡排序、插入排序、快速排序等,进行排序时会修改数组本身;
冒泡排序:经过一轮循环,将最大的数置换到末尾,然后进入下一轮循环,每轮均比上一轮的结束位置靠前一位;
import java.util.Arrays;
/**
-
@author : cunyu
-
@version : 1.0
-
@className : BubbleSort
-
@date : 2021/4/26 10:16
-
@description : 冒泡排序
*/
public class BubbleSort {
public static void main(String[] args) {
char[] chArray = {‘c’, ‘u’, ‘n’, ‘y’, ‘u’};
// 排序前
System.out.println(Arrays.toString(chArray));
for (int i = 0; i < chArray.length - 1; i++) {
for (int j = 0; j < chArray.length - 1 - i; j++) {
// 从大到小
if (chArray[j] < chArray[j + 1]) {
// 交换
char temp = chArray[j];
chArray[j] = chArray[j + 1];
chArray[j + 1] = temp;
}
}
}
// 冒泡排序后
System.out.println(Arrays.toString(chArray));
}
}
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
![img](https://img-blog.csdnimg.cn/img_convert/f3d486d07eaa059ef3d6129d614842da.jpeg)
最后
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!
%以上Java开发知识点,真正体系化!**
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
![img](https://img-blog.csdnimg.cn/img_convert/f3d486d07eaa059ef3d6129d614842da.jpeg)
最后
[外链图片转存中…(img-RhkMsKe4-1713524506421)]
[外链图片转存中…(img-FNmWgsGB-1713524506422)]
《互联网大厂面试真题解析、进阶开发核心学习笔记、全套讲解视频、实战项目源码讲义》点击传送门即可获取!