一、数组的定义与使用

1.1 数组的基本概念

数组指的就是一组相关变量的集合。

数组的定义:

  • 声明并开辟数组

    数据类型 数组名称 [] = new 数据类型[长度];

    数据类型 [] 数组名称 = new 数据类型[长度];

  • 分步完成

    声明数组:数据类型 数组名称[] = null;

    开辟数组: 数组名称 = new 数据类型[长度];

1、当数组开辟空间后,可以采用 "数组名称[下标]" 的形式进行访问。如果超出数组长度,那么会出现数组越界异常(ArrayIndexOutOfBoundsException)。

2、以上给出的数组定义结构采用的是动态初始化方式,即:数组会先开辟内存空间,数据内容为其数据类型的默认值。

3、由于数组是一种顺序的结构,并且数组的长度都是固定的,那么可以使用循环的方式输出,很明显 for 循环,而且 java 里为了方便数组的输出提供有一个 “数组名称.length” 的属性,可以取得数组的长度。

for(int i=0; i<data.length; i++){
System.out.println( data[i]);
}

1.2 内存空间

​ 虽然数组比较简单,但是其麻烦的问题在于,它也属于引用类型,也有内存分配,与对象保存唯一的区别在于:对象中的堆内存保存的是属性内容,数组对象中的堆内存保存的是数组里的内容

举例:用内存关系来描述下面的关系

int data [] = new int [3];
data[0] = 10;
data[1] = 20;
data[2] = 30;

以上是第一种数组定义的语法,下面更换第二种:

int data [] = null;
data = new int[3];
data[0] = 10;
data[1] =20;
data[2] =30;

1.3 数组的引用传递

既然数组属于引用数据类型,那么数组一定可以发生引用传递。

举例:数组的引用传递

int data [] = new int[3];
data[0] = 10;
data[1] =20;
data[2] =30;
int temp [] = data;
temp[0] =99;

1.4 数组的静态初始化

​ 以上数组的定义格式严格来讲是属于动态初始化,它的操作特点:先开辟数组空间,而后为数组中的内容进行赋值。

​ 和对象初始化相比,对象可以在定义时通过构造函数进行初始化。类似的:

在数组定义之中还提供有静态初始化的操作,即数组定义的同时就设置好了数组内容。

  • 格式一,简化格式: 数据类型 数组名称 [] = {值,值,值,...}

  • 格式二,完整格式: 数据类型 数组名称 [] = new 数据类型[] {值,值,值,...}

    int data [] = new int[]{10,20,30};
    for(int i=0; i<data.length; i++){
    System.out.println( data[i]);
    }

在实际工作中,数组是会存在的,但是它的内容大部分情况下是通过传递的数据而动态生成的,很少使用这种先开辟数组而后去使用的情况。

​ 虽然数组支持顺序的数据访问操作,但是数组有一个最大的缺点——长度不能被改变,所以在开发之中才不会去应用数组,但是会使用到数组的概念。

二、数组与方法参数的传递

2.1 数组的引用传递

举例:一个数组传递的程序

public class ArrayDemo{
public static void main(String args[]){
int data [] = new int[]{11,12,13};
changeData(data);
for(int i=0;i<data.length; i++){
System.out.println(data[i]);
}
}
public static void changeData(int [] temp){
for(int i=0;i<temp.length; i++){
temp[i] = temp[i]*2;
}
}
}

2.2 数组排序

实现一个数组排序

下面给出(升序)排序的基本原理(冒泡排序):每次取一个数与其他数比较,如果大于则交换位置。

  • 原始数据:2,1,9,0,5,3,7,6,8;

  • 第一次排序:1、2、0、5、3、7、6、8、9 ;

  • 第二次排序:1、0、2、3、5、6、7、8、9;

  • 第三次排序:0、1、2、3、5、6、7、8、9。

    以上只是给出了排序的基础原理过程,但是会根据数据的不同会出现不同的排序次数,但是不管有多少个数据,总的排序次数不会超过数组的长度。所以只要排序的次数达到 长度*长度,那么所要排序的数组一定会排序成功。

基础的实现:

public class SortArray{
public static void main(String args[]){
int data [] = new int []{2,1,9,0,5,3,7,6,8};
sort(data);
print(data); }
public static void sort(int[] arr){
for (int i=0; i<arr.length-1; i++ ) {
for (int j=0; j<arr.length-1 ;j++ ) {
if (arr[j] > arr[j+1]) {
int temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
public static void print(int[] arr){
for (int i=0;i<arr.length ;i++ ) {
System.out.print(arr[i] + "\\n");
}
}
}

2.3 数组转置

实现数组的转置(首尾交换)。

一维数组的实现:

原始数组:1、2、3、4、5、6、7、8;

转置后的数组:8、7、6、5、4、3、2、1;

如果要实现转置的操作,有两个思路:

  • 定义新的数组,将原始数组按照倒序的方式插入到新的数组中,随后改变原始数组引用。
public class ArrayDemo{
public static void main(String args[]){
int data [] = new int[]{1,2,3,4,5,6,7,8};
int temp [] = new int[data.length];
zhuanZhi(data,temp);
data = temp;
print(data);
}
public static void zhuanZhi(int[] arr1, int[] arr2){
for(int i=0; i< arr2.length; i++){
arr2[i] = arr1[arr2.length-1-i];
}
// arr1 = arr2;
}
public static void print(int [] arr){
for(int i=0; i< arr.length; i++){
System.out.print(arr[i]+ ",");
}
}
}

虽然以上的代码实现了转置,但是代码里会产生垃圾。下面看第2种方法:

  • 利用算法,在一个数组上完成转置操作:

    原始数组:1、2、3、4、5、6、7、8;

    第一次转置:8、2、3、4、5、6、7、1;

    第二次转置:8、7、3、4、5、6、2、1;

    …...

public class ArrayDemo{
public static void main(String args[]){
int data [] = new int[]{1,2,3,4,5,6,7,8};
reverse(data);
print(data);
}
public static void reverse(int[] arr){
int len = arr.length/2;
int head = 0;
int tail = arr.length-1;
for(int i=0; i< len; i++){
int temp = arr[head];
arr[head] = arr[tail];
arr[tail] = temp;
head++;
tail--;
}
}
public static void print(int [] arr){
for(int i=0; i< arr.length; i++){
System.out.print(arr[i]+ ",");
}
}
}

三、数组操作方法

java 本身针对于数组是有提供类库支持的。下面有两个与数组有关的操作:

3.1 数组拷贝

可以将一个数组的部分内容拷贝到另一数组中

语法: System.arraycopy(源数组名称,源数组拷贝开始索引,目标数组名称,目标数组拷贝开始索引,长度)。

举例:实现数组拷贝

数组A: 1、2、3、4、5、6、7、8;

数组B: 11、22、33、44、55、66、77、88;

要求拷贝后的数组: 11、22、5、6、7、66、77、88

代码为

public class ArrayDemo{
public static void main(String args[]){
int dataA [] = new int[]{1,2,3,4,5,6,7,8};
int dataB [] = new int[]{11,22,33,44,55,66,77,88};
System.arraycopy(dataA,4,dataB,2,3);
print(dataB);
}
public static void print(int [] arr){
for(int i=0; i< arr.length; i++){
System.out.print(arr[i]+ ",");
}
}
}

3.2 数组排序

​ 之前给出了排序的基本操作,但是在开发里面如果要进行排序,只需要使用如下代码即可。语法: Arrays.sort();

int data [] = new int []{3,6,1,8,0};
Arrays.sort(data);

四、对象数组(重点)

​ 数组是引用类型,对象也是引用类型,所以如果是对象数组的话表示一个引用类型里面嵌套了引用类型。之前使用的数组都是基于基本数据类型的数组,但是所有的引用数据类型也同样可以定义数组,这样的数组称为对象数组。如果要想定义对象数组(以类为例),可以采用如下的形式完成:

4.1 动态初始化

  1. 声明并开辟对象数组:

    类名称 对象数组名称[] = new 类名称[长度];

  2. 分步完成:

    • 先声明对象数组: 类名称 对象数组名称[] = null;
    • 开辟对象数组: 对象数组名称 = new 类名称[长度];

举例:对象数组的动态初始化

	Employee emp[] = new Employee[3];
emp[0] = new Employee("Alice","Java 开发", 1000);
emp[1] = new Employee("Bob","JSP 开发", 1000);
emp[2] = new Employee("Candy","Android 开发", 1000);

对象数组实际上就是将多个对象交给数组管理。

4.2 静态初始化

类名称 对象数组名称[] = new 类名称[]{实例化对象,...};

举例:对象数组的静态初始化

Employee emp[] = new Employee[]{
new Employee("Alice","Java 开发", 1000),
new Employee("Bob","JSP 开发", 2000),
new Employee("Candy","Android 开发", 3000)
};

注意,这里不要写数组长度。

4.3 一段总结

  1. 数组用的很少,但是一定会用,而且数组的相关逻辑关系比较麻烦;
  2. 对象数组的定义语法,对象数组 = 多个对象。
  3. 数组有一个最大的天生短板:长度固定,这个限制了数组在开发中的出现。
  4. 数组的排序:Arrays.sort()。

【6】java之数组的定义和使用的更多相关文章

  1. 《Java基础——数组的定义与使用》

    Java基础--数组的定义与使用       一. 一维数组: 格式一: 数组类型 数组变量[]=new 数据类型[长度]; //需要后续赋值,且后续赋值时只能为单个元素赋值. 或 数组类型 数组变量 ...

  2. C和Java中数组的定义

    在学习C和Java中,关于数组的定义两者不同,在初学的时候,容易产生混淆,现在将两者对比下. 1.初始化 在C语言中,关于一维数组的定义: 完全初始化  int a[5]={1,2,3,4,5},对于 ...

  3. Java基础--数组的定义

    1.数组的定义 数组:一组能够储存相同数据类型值的变量的集合. 2.数组的赋值方式 (1)使用默认的初始值来初始化数组中的每一个元素 语法:数组元素类型[]数组名 = new数组元素类型[数组中元素的 ...

  4. java中数组的定义

    1. 一维数组 int[] arr = new int[3];//需要一个容器,但是暂时不给具体的数值 int[] arr = new int[3]{1,2,3};//直接给定具体数值 int[] a ...

  5. Java中数组的定义与使用(代码+例子)

    学习目标: 掌握一维数组的使用 学习内容: 1.一维数组的定义 数组(Array),是把具有 相同类型 的多个常量值 有序组织 起来的一种数据形式.这些按一定顺序排列的多个数据称为数组.而数组中的每一 ...

  6. java——关于数组的定义 和 访问修饰符的修饰内容

    public class Shuzu { public static void main(String[] args) { // 定义数组 必须初始化长度,没有初始化要放数据 int[] in = { ...

  7. Java中数组的定义方式

    数组定义方式一 动态方式(指定数组的长度) 格式: 数组存储的数据类型[]数组名字 = new 数组存储的数据类型[长度]; [] : 表示数组. 数组名字:为定义的数组起个变量名,满足标识符规范,可 ...

  8. Java中数组的定义,初始化和使用

    定义:数组是数据类型相同的,用一个标志符名称封装在一起的一个对象序列或基本类型数据序列(一组相同数据类型元素的集合,并且分配一块连续的内存来存储). 格式:int[] a1(常用)  或者 int a ...

  9. Java学习--数组的定义和使用

    1. 数组分配了空间,未赋值 public class ArrayDemo01{ public static void main(String args[]){ int score[] = null ...

  10. JAVA数组的定义及用法

    数组是有序数据的集合,数组中的每一个元素具有同样的数组名和下标来唯一地确定数组中的元素. 1. 一维数组 1.1 一维数组的定义 type arrayName[]; type[] arrayName; ...

随机推荐

  1. 聊聊CPU的发展历程之单核、多核、超线程

    作者:小牛呼噜噜 | https://xiaoniuhululu.com 计算机内功.JAVA底层.面试.职业成长相关资料等更多精彩文章在公众号「小牛呼噜噜」 大家好,我是呼噜噜,在计算机的早期,In ...

  2. 自研ORM框架 实现类似EF Core Include 拆分查询 支持自定义条件、排序、选择

    Baozi, I'm Mr.Zhong I like to brush TikTok, I know that anchors like to call it that, haha!Recently, ...

  3. nuxt之vuex的使用

    先来了解一下官网:https://www.nuxtjs.cn/guide/vuex-store 一.首先在 store 文件下新建一个index.js文件 const state = () => ...

  4. STL map容器常用API

    map容器:键值和实值是分开的,排序规则按照键值排序 #define _CRT_SECURE_NO_WARNINGS #include<iostream> #include<map& ...

  5. 迁移学习(DANN)《Domain-Adversarial Training of Neural Networks》

    论文信息 论文标题:Domain-Adversarial Training of Neural Networks论文作者:Yaroslav Ganin, Evgeniya Ustinova, Hana ...

  6. Python从0到1丨细说图像增强及运算

    摘要:本文主要讲解常见的图像锐化和边缘检测方法,即Roberts算子和Prewitt算子. 本文分享自华为云社区<[Python从零到壹] 五十七.图像增强及运算篇之图像锐化Roberts.Pr ...

  7. dotnet 代码优化 聊聊逻辑圈复杂度

    本文属于 dotnet 代码优化系列博客.相信大家都对圈复杂度这个概念很是熟悉,本文来和大家聊聊逻辑的圈复杂度.代码优化里面,一个关注的重点在于代码的逻辑复杂度.一段代码的逻辑复杂度越高,那么维护起来 ...

  8. ArcGIS工具 - 批量删除空图层

    为了减少数据的冗余,我们经常需将数据库中的空图层(没有任何记录的要素类或表)删除,删除数据本来是一个很简单的操作,但如果数据量大,则需通过程序来处理.例如,删除成百上千个标准分幅DLG数据库中等高线数 ...

  9. 10分钟在 Rainbond 上部署 mall 电商项目

    很多小伙伴在学习 mall 电商项目时,都会在部署上折腾许久,虽然目前已经提供了很多种部署方式,比如 在 Linux 上部署 mall .使用 Docker 或 DockerCompose 部署 ma ...

  10. test20230111考试总结 -2023寒图论专题

    前言 赛时得分情况: A B C D E F G H I \(\texttt{Total}\) \(\texttt{Rank}\) \(100\) \(100\) \(10\) \(58\) \(54 ...