Day24-20260120

小技巧

Ctrl+/,快速注释选中的代码

数组的四个基本特点

其长度是确定的。数组一旦被创建,他的大小就是不可以改变的。

其元素必须是相同类型,不允许出现混合类型。

数组中的元素可以是任何数据类型,包括基本类型和引用类型。

数组变量属引用类型,数组也可以看成是对象,数组中的每个元素相当于该对象的成员变量。

数组本身就是对象,Java中对象是在堆中的,因此数组无论保存原始类型还是其他对象类型,数组对象本身是在堆中的。

数组边界

下标的合法区间:[0,length-1],如果越界就会报错;

java 复制代码
public static void main(String[] args){
    int[] a=new int[2];
    System.out.println(a[2]);
}

ArrayIndexOutOfBoundsException:数组下标越界异常!

小结:

数组是相同数据类型(数据类型可以为任意类型)的有序集合

数组也是对象。数组元素相当与对象的成员变量

数组长度的确定的,不可变的。如果越界,则报:ArrayIndexOutOfBounds

java 复制代码
package com.array;

public class ArrayDemo02 {
    public static void main(String[] args) {
        //静态初始化:创建 + 赋值
        int[] a = {1,2,3,4,5,6,7,8};
        Man[] mans = {new Man(),new Man()};//引用类型的数组
        System.out.println(a[0]);
        for (int i = 0; i <= a.length; i++) {
            System.out.println(a[i]);
        }
        //动态初始化:包含默认初始化
//        int[] b = new int[10];
//        b[0] = 10;
//        b[1] = 10;
//        System.out.println(b[0]);
//        System.out.println(b[1]);
//        System.out.println(b[2]);
//        System.out.println(b[3]);
    }
}
java 复制代码
1
1
2
3
4
5
6
7
8
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 8
	at com.array.ArrayDemo02.main(ArrayDemo02.java:11)

进程已结束,退出代码为 1

数组使用

for-Each 循环

java 复制代码
package com.array;

public class ArrayDemo03 {
    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="+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="+max);
    }
}
java 复制代码
1
2
3
4
5
=========================
sum=15
===========================
max=5

进程已结束,退出代码为 0

array.for+enter:增强型for循环

java 复制代码
package com.array;

public class ArrayDemo04 {
    public static void main(String[] args) {
        int[] arrays = {1,2,3,4,5};
        //jdk1.5,没有下标
        for (int array : arrays) {
            System.out.println(array);
        }
    }
}
java 复制代码
1
2
3
4
5

进程已结束,退出代码为 0

数组作方法入参

java 复制代码
package com.array;

public class ArrayDemo04 {
    public static void main(String[] args) {
        int[] arrays = {1,2,3,4,5};
//        //jdk1.5,没有下标
//        for (int array : arrays) {
//            System.out.println(array);
//        }
    printArray(arrays);
    }
    //打印数组元素
    public static void printArray(int[] arrays){
        for (int i = 0; i < arrays.length; i++) {
            System.out.print(arrays[i]+" ");
        }
    }
}
java 复制代码
1 2 3 4 5 
进程已结束,退出代码为 0

数组作返回值

java 复制代码
package com.array;

public class ArrayDemo04 {
    public static void main(String[] args) {
        int[] arrays = {1,2,3,4,5};
//        //jdk1.5,没有下标
//        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;
    }
}
java 复制代码
5 4 3 2 1 
进程已结束,退出代码为 0
相关推荐
m0_502724952 小时前
飞书真机调试
开发语言·前端·javascript
一个龙的传说2 小时前
xshell下载
java
ValhallaCoder2 小时前
Day53-图论
数据结构·python·算法·图论
C雨后彩虹2 小时前
羊、狼、农夫过河
java·数据结构·算法·华为·面试
java资料站2 小时前
SpringAI+DeepSeek大模型应用开发实战
java
Elastic 中国社区官方博客2 小时前
使用瑞士风格哈希表实现更快的 ES|QL 统计
大数据·数据结构·sql·elasticsearch·搜索引擎·全文检索·散列表
进击的CJR2 小时前
redis cluster 部署
java·redis·mybatis
重生之后端学习3 小时前
19. 删除链表的倒数第 N 个结点
java·数据结构·算法·leetcode·职场和发展
qq_12498707533 小时前
基于小程序中医食谱推荐系统的设计(源码+论文+部署+安装)
java·spring boot·后端·微信小程序·小程序·毕业设计·计算机毕业设计