栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

【黑马程序员 Java 笔记】数组

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【黑马程序员 Java 笔记】数组

目录

1、数组的定义

2、数组的初始化

        1)动态初始化

        2)静态初始化

3、访问

        1)数组的访问

        2)数组元素的访问

4、内存分配

        1)栈内存

        2)堆内存

5、数组操作的两个常见小问题

        1)索引越界

        2)空指针异常

6、数组常见操作

        1)遍历

        2)获取最值

1、数组的定义

        1)int[] arr; —— 定义了一个int类型的数组,数组名为arr

        2)int arr[]; —— 定义了一个int类型的变量,变量名为arr数组

2、数组的初始化

        1)动态初始化

                初始化时,指定数组长度,由系统为数组分配初始值 —— int[] arr = new int[3];

默认值
整数0
浮点数0.0
布尔值false
字符空字符
引用数据类型null

        2)静态初始化

                初始化时,指定每个数组元素的初始值,由系统决定数组长度 —— int arr[] = new int[]{1,2,3};

3、访问

        1)数组的访问

                arr

        2)数组元素的访问

                arr[0]

4、内存分配

        1)栈内存

                存储局部变量(定义在方法中的变量,如arr) —— 使用完毕,立即消失

        2)堆内存

                存储new出来的内容(实体,对象)—— 每一个new出来的东西都有一个地址值。使用完毕,会在垃圾回收器空闲时被回收。

5、数组操作的两个常见小问题

        1)索引越界

                访问了数组中不存在的索引对应的元素 —— ArrayIndexOutOfBoundsException

int[] arr = new int[3];
System.out.println(arr[3]);

        2)空指针异常

                访问的数组已经不再指向堆内存的数据 —— NullPointerException

int[] arr = new int[3];
System.out.println(arr[2]);
arr = null;
System.out.println(arr[0]);

6、数组常见操作

        1)遍历
for(int i = 0; i < arr.length; i++)
{
    System.out.println(arr[i]);
}

        2)获取最值

                1、定义一个变量,用于保存最大值(或最小值)

                        int max;

                2、取数组中的第一个数据作为变量的初始值

                        max = arr[0];

                3、与数组中剩余的数据逐个比对,每次比对将最大值保存到变量中

for(int i = 1; i < arr.length; i++)
{
    if(arr[i] > max)
        {
            max = arr[i];
        }
}

                4、循环结束后打印变量的值

                        System.out.println("max = " + max);

public class Array {
    public static void main(String[] args) {
        int[] arr = {11, 22, 33, 44, 55};

        // 遍历
        for (int i = 0; i < arr.length; i++)
        {
            System.out.println(arr[i]);
        }

        // 获取最大值
        int max = arr[0];
        for(int j = 1; j < arr.length; j++)
        {
            if(arr[j] > max)
            {
                max = arr[j];
            }
        }
        System.out.println("max = " + max);
    }
}

// 运行结果

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/735578.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号