Java数组从定义到操作全解析

 更新时间:2025年11月25日 09:14:42   作者:H的代码  
这篇文章详细介绍了Java数组的概念、声明、创建、访问、初始化、边界、基础操作以及Arrays类的常用方法,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧

数组概述

数组的定义

  • 数组是相同数据类型数据的有序集合。
  • 数组描述的是相同类型的若干个数据,按照一定的先后次序排列组合而成。
  • 其中,每一个数据称作一个数组元素,每一个数组元素可以通过下标访问它们。

数组声明创建

  • 首先必须声明数组变量,才能在程序中使用数组。下面是声明数组变量(定义)的语法:
dataType[] arrayRefvar;     //首选的方法
或
dataType arrayRefVar[];     //效果相同,但不是首选方法
  • Java语言使用new操作符来创建数组,语法如下:
dataType[] arrayRefVar = new dataType[arraySize];
//                          数组范围[0-arraySize)
  • 数组的元素时通过索引访问的,数组索引从0开始
  • 获取数组长度:
arrays.length
  • 计算所有元素的和:
public class Demo01 {
    public static void main(String[] args) {
        //基本数据类型:变量的类型 变量的名称 = 变量的值
        //数组类型:变量类型[] 数组名 = new 变量类型[数组大小]
        int[] nums;     //1.声明一个数组
        nums = new int[3];     //2.创建一个数组
        //int[] nums = new int[10]; //1.2.等价于
        //3.给数组元素中赋值
        nums[0] = 1;
        nums[1] = 2;
        nums[2] = 3;
        System.out.println(nums);    //数组的地址
        //计算所有元素的和
        int sum = 0;
        //获取数组长度:array.length
        for (int i = 0; i <nums.length ; i++) {
            sum = sum + nums[i];
        }
        System.out.println("数组和为:"+sum);
    }
}

内存分析

数组三种初始化

静态初始化

int[] a = {1,2,3};//静态初始化:创建 + 赋值;基本类型
Man[] mans = {new Man(1,1), new Man(2,2)};//引用类型

动态初始化(包含默认初始化)

int[] a = new int[2];//声明+初始化
a[0] = 1;   //赋值
a[1] = 2;   //赋值

数组的默认初始化

  • 数组是引用类型,它的元素相当于类的实例变量,因此数组一经分配空间,其中的每个元素也被按照实例变量同样的方式被隐式初始化
public class Demo02 {
    public static void main(String[] args) {
        //静态初始化:创建 + 赋值
        int[] a = {1,2,3,4,5,6,7,8,9};
        System.out.println(a[0]);
        System.out.println("------------------");
        //动态初始化:包含默认初始化
        int[] b = new int[10];
        b[0] = 10;  //对数组0号位置赋值
        b[1] = 10;  //对数组1号位置赋值
        //遍历数组b,除了0、1号位,其余位被默认初始化
        for (int i : b) {
            System.out.print(i+"\t");
        }
    }
}

数组的四个基本特点

  • 其长度是确定的。数组一旦被创建,它的大小就是不可以改变的。
  • 其元素必须是相同类型,不允许出现混合类型。
  • 数组中的元素可以是任何数据类型,包括基本类型和引用类型。
  • 数组变量属引用类型,数组也可以看成是对象,数组中的每个元素相当于该对象的成员变量。
  • 数组本身就是对象,Java中对象是在堆中的,因此数组无论保存原始类型还是其他对象类型,数组对象本身是在堆中的。

数组边界

  • 下标的合法区间:[0,length-1],如果越界就会报错
public static void main(String[] args){
    int[] a = new int[2];
    System.out.println(a[2]);
}
  • ArrayIndexOutOfBoundsException 数组下标越界异常

一维数组的基础操作

public class Demo03 {
    public static void main(String[] args) {
        int[] arrays = {1,2,3,4,5};
        //打印全部的数组元素
        for (int i = 0; i < arrays.length; i++) {
            System.out.println(arrays[i]);
        }
        System.out.println("----------------");
        //计算所有元素的和
        int sum = 0;
        for (int i = 0; i < arrays.length; i++) {
            sum += arrays[i];
        }
        System.out.println("数组的元素和为:"+sum);
        System.out.println("----------------");
        //查找数组内元素的最大值
        int max = arrays[0];
        for (int i = 0; i < arrays.length; i++) {
            if (arrays[i]>max){
                max = arrays[i];
            }
        }
        System.out.println("数组内元素的最大值为:"+max);
    }
}
​

总结:

  • 数组是相同数据类型(数据类型可以为任意类型)的有序集合
  • 数组也是对象。数组元素相当于对象的成员变量
  • 数组长度是确定的,不可变的。如果越界,会报错(ArrayIndexOutOfBoundsException)

数组使用

  • Java从JDK 5开始引入: for-each(增强型for循环)
for(元素类型 变量名 : 遍历对象) {
    // 循环体
}
  • 数组做方法入参(传数组打印)
  • 数组作返回值(反转数组)
public class Demo04 {
    public static void main(String[] args) {
        //例题:将数组反转并输出
        int[] arrays = {1,2,3,4,5};
        //ava从JDK 5开始引入for-each,缺点:不能通过下标访问元素进行修改
//        for (int array : arrays) {
//            System.out.println(array);
//        }
//        printArray(arrays);
        int[] reverse = reverse(arrays);    //数组作返回值
        printArray(reverse);    //数组做方法入参
    }
    //打印数组元素
    public static void printArray(int[] arrays){
        for (int i = 0; i < arrays.length; i++) {
            System.out.print(arrays[i]+" ");
        }
    }
    //反转数组
    public static int[] reverse(int[] arrays){
        int[] result = new int[arrays.length];
        //反转操作
        for (int i = 0,j=result.length-1; i < arrays.length; i++,j--) {
            result[j] = arrays[i];
        }
        return result;
    }
}

多维数组

  • 多维数组可以看成是数组的数组,比如二维数据就是一个特殊的一维数组,其每一个数组元素又都是一个一维数组。
  • 二维数组
int a[][] = new int[2][5];
  • 解析:以上二维数组a可以看成一个两行五列的数组。

二维数组的基础操作

public class Demo05 {
    public static void main(String[] args) {
        int[][] array = {{1,2,3},{4,5,6},{7,8,9},{10,11,12},{13,14,15}};
        //1.遍历二维数组
        for (int i = 0; i < array.length; i++) {
            for (int j = 0; j < array[i].length; j++) {
                System.out.println(array[i][j]);
            }
        }
        System.out.println("-------------------");
        //2.取二维数组的所有元素和
        int sum = 0;
        for (int i = 0; i < array.length; i++) {
            for (int j = 0; j < array[i].length; j++) {
                sum += array[i][j];
            }
        }
        System.out.println("数组的所有元素和为:"+sum);
        System.out.println("-------------------");
        //3.取二维数组中元素的最大值
        int result = 0;
        for (int i = 0; i < array.length; i++) {
            for (int j = 0; j < array[i].length; j++) {
                if (array[i][j] > result){
                    result = array[i][j];
                }
            }
        }
        System.out.println("二维数组中元素的最大值为:"+result);
        System.out.println("-------------------");
        //4.打印二维数组的第一行数据
        //方法一:
        System.out.println(array[0]);
        System.out.println(array[0][0]);
        System.out.println(array[0][1]);
        System.out.println(array[0][2]);
        System.out.println("-------------------");
        //方法二:
        printArray(array[0]);
    }
    public static void printArray(int[] arrays){
        for (int i = 0; i < arrays.length; i++) {
            System.out.print(arrays[i]+" ");
        }
    }
}

Arrays类

  • 数组的工具类Java.util.Arrays
  • 由于数组对象本身并没有什么方法可以供我们调用,但API中提供了一个工具类Arrays供我们使用,从而可以对数据对象进行一些基本的操作。
  • Arrays类中的方法都是static修饰的静态方法,在使用的时候可以直接使用类名进行调用,而“不用”使用对象来调用(注意:是“不用”而不是“不能”)
  • 具有以下常用功能:
    • 给数据赋值:通过fill方法。
    • 对数组排序:通过sort方法,按升序。
    • 比较数组:通过equals方法比较数组中元素值是否相等。
    • 查找数组元素:通过binarySearch方法能对排序号的数据进行二分查找法操作。
import java.util.Arrays;
public class Demo06 {
    public static void main(String[] args) {
        int[] a = {45,132,864,16,4,6,889,456,2};
        System.out.println(a); //[I@1b6d3586
        //用Arrays提供的方法(toString)打印数组的元素
        System.out.println(Arrays.toString(a));
        //通过自己创建的方法(printArray)来打印数组的元素
        printArray(a);
        //-----------------------------------
        System.out.println();
        //用Arrays提供的方法对数组进行排序后输出
        Arrays.sort(a); //对数组进行排序:默认升序
        System.out.println(Arrays.toString(a));
        //-----------------------------------
        //用Arrays提供的方法对数组进行填充
        Arrays.fill(a,0);   //数组填充
        System.out.println(Arrays.toString(a));
        Arrays.fill(a,2,4,1);//对数组中的[2,4)位进行填充
        System.out.println(Arrays.toString(a));
    }
    public static void printArray(int[] a){
        for (int i = 0; i < a.length; i++) {
            if (i==0){
                System.out.print("[");
            }
            if (i==a.length-1){
                System.out.print(a[i]+"]");
            }else {
                System.out.print(a[i]+", ");
            }
        }
    }
}

例题:冒泡排序

  • 八大排序:直接插入排序、希尔排序、简单选择排序、堆排序、冒泡排序、快速排序、归并排序、基数排序;冒泡排序是最出名的排序算法之一;
  • 俩层循环,外层冒泡轮数,里层依次进行俩数之间的比较
  • 冒泡排序算法时间复杂度是O(n^2)
import java.util.Arrays;
public class Demo07 {
    public static void main(String[] args) {
        /*
            冒泡排序:思路
            1.比较数组中,两个相邻的元素,如果第一个数比第二个数大,我们就交换他们的位置
            2.每一次比较,都会产生出一个最大或者最小的数字
            3.下一轮则可以少一次排序(array.length-1-i)
            4.依次循环,直到结束!
        */
        int[] a = {2,6,13,57,87,64,135,6,5};
        int[] sort = sort(a);
        System.out.println(Arrays.toString(sort));
    }
    public static int[] sort(int[] array){
        //临时变量
        int temp = 0;
        //外层循环,判断数组需要进行多少次
        for (int i = 0; i < array.length-1; i++) {
            //内层循环,依次比较相邻的两个数,如果第一个数比第二个数大,则交换位置(每一轮确定一个最大值)
            for (int j = 0; j < array.length-1-i; j++) {
                if (array[j]>array[j+1]){
                    temp = array[j];
                    array[j] = array[j+1];
                    array[j+1] = temp;
                }
            }
        }
        return array;
    }
}

优化冒泡排序

import java.util.Arrays;
public class Demo08 {
    public static void main(String[] args) {
        //Demo07冒泡排序优化
        /*
            冒泡排序
            1.比较数组中,两个相邻的元素,如果第一个数比第二个数大,我们就交换他们的位置
            2.每一次比较,都会产生出一个最大或者最小的数字
            3.下一轮则可以少一次排序(array.length-1-i)
            4.依次循环,直到结束!
        */
        int[] a = {2,6,13,57,87,64,135,6,5};
        int[] sort = sort(a);
        System.out.println(Arrays.toString(sort));
    }
    public static int[] sort(int[] array){
        //临时变量
        int temp = 0;
        //外层循环,判断数组需要进行多少次
        for (int i = 0; i < array.length-1; i++) {
            boolean flag = false;//通过flag标志位减少没有意义的比较
            //内层循环,依次比较相邻的两个数,如果第一个数比第二个数大,则交换位置(每一轮确定一个最大值)
            for (int j = 0; j < array.length-1-i; j++) {
                if (array[j]>array[j+1]){
                    temp = array[j];
                    array[j] = array[j+1];
                    array[j+1] = temp;
                    flag = true;    //进行了换位flag则变成true
                }
            }
            //没有进入内循环判断,说明该序列已经是有序的了,则可以跳出循环
            if (flag==false){
                break;
            }
        }
        return array;
    }
}

到此这篇关于Java数组详解:从定义到操作全解析的文章就介绍到这了,更多相关java数组定义内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Java实现字符编码转换(utf-8/gbk)

    Java实现字符编码转换(utf-8/gbk)

    这篇文章主要为大家详细介绍了如何使用Java实现字符编码转换工具,主要针对UTF-8和GBK两种编码格式,文中的示例代码讲解详,需要的可以了解下
    2025-03-03
  • Java中ThreadPoolExecutor拒绝策略踩坑

    Java中ThreadPoolExecutor拒绝策略踩坑

    本文主要介绍了Java中ThreadPoolExecutor拒绝策略踩坑,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • Java静态方法不能调用非静态成员的原因分析

    Java静态方法不能调用非静态成员的原因分析

    在Java中,静态方法是属于类的方法,而不是属于对象的方法,它可以通过类名直接调用,无需创建对象实例,非静态成员指的是类的实例变量和实例方法,它们需要通过对象实例才能访问和调用,本文小编将和大家一起探讨Java静态方法为什么不能调用非静态成员
    2023-10-10
  • idea生成类注释和方法注释的正确方法(推荐)

    idea生成类注释和方法注释的正确方法(推荐)

    这篇文章主要介绍了idea生成类注释和方法注释的正确方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-11-11
  • 时间中间键的整理

    时间中间键的整理

    这篇文章主要介绍了时间中间键的整理的相关资料,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,需要的朋友可以参考下
    2017-10-10
  • Mybatis环境搭建及文件配置过程解析

    Mybatis环境搭建及文件配置过程解析

    这篇文章主要介绍了Mybatis环境搭建及文件配置过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-08-08
  • java 使用线程监控文件目录变化的实现方法

    java 使用线程监控文件目录变化的实现方法

    这篇文章主要介绍了java 使用线程监控文件目录变化的实现方法的相关资料,希望通过本文能帮助到大家,需要的朋友可以参考下
    2017-10-10
  • Java中Properties类的操作实例详解

    Java中Properties类的操作实例详解

    这篇文章主要介绍了Java中Properties类的操作实例详解的相关资料,需要的朋友可以参考下
    2017-04-04
  • 一篇文章带你入门java泛型

    一篇文章带你入门java泛型

    这篇文章主要介绍了java泛型基础知识及通用方法,从以下几个方面介绍一下java的泛型: 基础, 泛型关键字, 泛型方法, 泛型类和接口,感兴趣的可以了解一下
    2021-08-08
  • IDEA集成DeepSeek通过离线安装解决无法安装Proxy AI插件问题(最新推荐)

    IDEA集成DeepSeek通过离线安装解决无法安装Proxy AI插件问题(最新推荐)

    许多开发者尝试通过安装Proxy AI等插件将AI能力引入IDEA,但在实际使用中常遭遇插件安装失败、网络连接不稳定或兼容性冲突等问题,本文给大家介绍IDEA集成DeepSeek通过离线安装解决无法安装Proxy AI插件问题,感兴趣的朋友一起看看吧
    2019-12-12

最新评论