0%
这是一片思考的空间 -- arthinking
Spring 重构&代码整洁之道 软件设计 JVM 并发编程 数据结构与算法 分布式 存储 网络 微服务 设计模式
Java技术栈 - 涉及Java技术体系

Java基础笔记 - 数组 二维数组 三维数组 Arrays类

1、数组:

相同数据的集合。

1.1、定义数组的方法:

类型[] 变量名 = new 类型[数组元素个数];

1
int[]a = new int[10];

first index:0; max:length-1;

1.2、创建和初始化数组:

1.2.1、创建时指定大小:

1
2
3
4
//创建时指定大小
int[] arrays = new int[2];
arrays[0] = 1;
arrays[1] = 2;

1.2.2、创建时赋初值:

1
int[] arrays2 = {1,2};

1.2.3、创建时赋初值(使用new关键字):

1
int[] arrays3 = new int[]{1,2};

1.3、数组的大小:

数组的大小是一个常量。一旦初始化一个数组之后数组的大小便固定了,不能再修改。

属性:length 数组长度。

1
public final int length;

1.4、数组默认值:

int类型不赋初值则默认赋值为0,引用类型默认为null。

1.5、数组的equals方法:

数组的equals方法只是使用了==判断是否同一个对象,所以,如果要判断两个数组包含的数值是否相等,最好使用Arrays类中的静态方法:

static boolean equals(int[] a, int[] a2)
如果两个指定的 int 型数组彼此相等,则返回 true。

1.6、数组的保存:

1
int[] a = new int[10]

a是一个引用,指向了生成的数组对象的首地址。数组中每个元素都是int类型的。

数组中保存的是引用。对象数组未赋值时为null。

2、二维数组:

二维数组是一种平面的二维结构,本质上是 数组的数组。

2.1、二维数组的创建和赋值:

2.1.1、等长数组:

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

2.1.2、可变数组:

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

以下创建为错误:

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

2.2、初始值:

1
int[][] a = new int[][]{ {1},{1,2}};

2.3、输出:

1
2
3
4
5
for(int i = 0; i<a.length; i++){
for(int j = 0; j<a[i].length; j++){
System.out.println(a[i][j]);
}
}

3、交换变量:

3.1、不使用中间变量交换整数的方法:

1
2
3
4
5
int a = 1;
int b = 2;
a = a + b;
b = a – b;
a = a – b;

3.2、通过方法实现两个整数的互换:

调用一下方法后并不会调用两个数:

1
2
3
4
5
public void swap(int a, int b){
int temp = a;
a = b;
b = temp;
}

传递数组,使之能够交换后改变:

1
2
3
4
5
public void swap(int[] a){
int temp = a[0];
a[0] = a[1];
a[0] = temp;
}

4、Arrays数组类:

public class Arrays
extends Object
此类包含用来操作数组(比如排序和搜索)的各种方法。此类还包含一个允许将数组作为列表来查看的静态工厂。

equals方法:

equals
public static boolean equals(int[] a,
int[] a2)
如果两个指定的 int 型数组彼此相等,则返回 true。如果两个数组包含相同数量的元素,并且两个数组中的所有相应元素对都是相等的,则认为这两个数组是相等的。换句话说,如果两个数组以相同顺序包含相同的元素,则两个数组是相等的。此外,如果两个数组引用都为 null,则认为它们是相等的。
参数:
a - 将测试其相等性的一个数组
a2 - 将测试其相等性的另一个数组
返回:
如果两个数组相等,则返回 true

copyOfRange方法:

static
<T,U> T[]
copyOfRange(U[] original, int from, int to, Class<? extends T[]> newType)
将指定数组的指定范围复制到一个新数组。

5、三维数组:

5.1、定义:

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

5.2、循环赋值:

1
2
3
4
5
6
7
int[][][] a = new int[1][2][3];
for(int i=0; i<a.length; i++){
for(int j=0; i<a[i].length; j++){
for(int k=0; k<a[i][j].length; k++)
System.out.println(a[i][j][k]);
}
}

欢迎关注我的其它发布渠道

订阅IT宅
内功修炼
Java技术栈
Java架构杂谈是IT宅精品文章公众号,欢迎订阅:
📄 网络基础知识:两万字长文50+张趣图带你领悟网络编程的内功心法 📄 HTTP发展史:三万长文50+趣图带你领悟web编程的内功心法 📄 HTTP/1.1:可扩展,可靠性,请求应答,无状态,明文传输 📄 HTTP/1.1报文详解:Method,URI,URL,消息头,消息体,状态行 📄 HTTP常用请求头大揭秘 📄 HTTPS:网络安全攻坚战 📄 HTTP/2:网络安全传输的快车道 📄 HTTP/3:让传输效率再一次起飞 📄 高性能网络编程:图解Socket核心内幕以及五大IO模型 📄 高性能网络编程:三分钟短文快速了解信号驱动式IO 📄 高性能网络编程:彻底弄懂IO复用 - IO处理杀手锏,带您深入了解select,poll,epoll 📄 高性能网络编程:异步IO:新时代的IO处理利器 📄 高性能网络编程:网络编程范式 - 高性能服务器就这么回事 📄 高性能网络编程:性能追击 - 万字长文30+图揭秘8大主流服务器程序线程模型
📄 Java内存模型:如果有人给你撕逼Java内存模型,就把这些问题甩给他 📄 一文带你彻底理解同步和锁的本质(干货) 📄 AQS与并发包中锁的通用实现 📄 ReentrantLock介绍与使用 📄 ReentrantReadWriteLock介绍与使用 📄 ReentrantLock的Condition原理解析 📄 如何优雅的中断线程 📄 如何优雅的挂起线程 📄 图解几个好玩的并发辅助工具类 📄 图解BlockingQueue阻塞队列
📄 消息队列那么多,为什么建议深入了解下RabbitMQ? 📄 高并发异步解耦利器:RocketMQ究竟强在哪里? 📄 Kafka必知必会18问:30+图带您看透Kafka
📄 洞悉MySQL底层架构:游走在缓冲与磁盘之间 📄 SQL运行内幕:从执行原理看调优的本质 📄 洞悉Redis技术内幕:缓存,数据结构,并发,集群与算法