【Java SE】数组的应用

news2024/11/23 16:37:34

 🔥博客主页🔥:【 坊钰_CSDN博客 】

欢迎各位点赞👍评论✍收藏⭐

目录

1. 数组的概念

1.1 为什么存在数组

1.2 数组是什么

1.3 数组的创建

1.4 数组的初始化

1.4.1 动态初始化

1.4.2 静态初始化

1.4.3 默认值

1.5 数组的使用

1.5.2 遍历数组

1.5.3 for - each 循环

2. 引用类型-数组

2.1 默认值 null

 3. 二维数组

 3.1 遍历二维数组

 4. 小结


 

1. 数组的概念

1.1 为什么存在数组

在生活中,存在多组数据情况有很多

比如:一个班级学生有50人,现在要统计所有学生的分数,难道要一个一个定义 50 个变量来统计吗?并非如此,这样很麻烦,那有没有更为方便的方法呢?

这就引出了数组的用法

1.2 数组是什么

数组是一段存储着相同元素空间,可以看成相同类型元素的一个集合

  • 是一段连续的空间
  • 元素类型必须一致
  • 每一个空间都有一个下标与之对应

1.3 数组的创建

创建数组的结构

类型名[] 数组名 = new 类型名[数组大小] 
public class Test {
    public static void main(String[] args) {

        //创建一个容纳 10 个 int 类型元素的数组 
        int[] array = new int[10];

        //创建一个容纳 10 个 double 类型元素的数组 
        double[] array1 = new double[10];

        //创建一个容纳 10 个 char 类型元素的数组 
        char[] array2 = new char[10];
    }
}

1.4 数组的初始化

创建好数组后,如何给空间添加元素呢?这里有两种初始化方法

1.4.1 动态初始化

指的是在创建数组时,直接确定数组的大小

double[] array1 = new double[10];
char[] array2 = new char[10];
int[] array = new int[10];

1.4.2 静态初始化

创建数组时,不指定数组的大小,而使用具体的数据来代替

double[] array1 = new double[]{1.0, 2.0, 3.0, 4.0};
int[] array2 = new int[]{1, 2, 3, 4, 5, 6, 7, 8};
char[] array = new char[]{'A', 'B', 'C', 'D'};

【注意】

  • 当用静态初始化时,[ ] 中不能写任何数字,否则会报错
  • 静态初始化时,new 类型名[]  这部分可以省略 
double[] array1 = {1.0, 2.0, 3.0, 4.0};
int[] array2 = {1, 2, 3, 4, 5, 6, 7, 8};
char[] array = {'A', 'B', 'C', 'D'};

1.4.3 默认值

对于未初始化的数组,数组中的元素是有默认值的

  • 对于引用类型,默认值位 null 

1.5 数组的使用

数组中的元素都是有下标的,从 0 开始到 n(数组的长度) - 1 结束

public class Test {
    public static void main(String[] args) {

        int[] array = {1, 2, 3, 4, 5, 6, 7, 8};
        System.out.println(array[0]);
        System.out.println(array[3]);

    }
}

 那么这代码就分别打印出 1 和 4

1.5.2 遍历数组

public class Test {
    public static void main(String[] args) {
        int[] array = {1, 2, 3, 4, 5, 6, 7, 8};
        for(int i = 0; i < array.length; i++) {
            System.out.print(array[i] + " ");
        }
    }
}

  •  其中 array.length 为数组的长度

1.5.3 for - each 循环

public class Test {
    public static void main(String[] args) {
        int[] array = {1, 2, 3, 4, 5, 6, 7, 8};
        for(int x : array) 
            System.out.print(x + "  ");
    }
}

 for - each 结构

for(int x : 数组名)
System.out.print(x);

该循环会依次遍历数组中元素,在打印 

2. 引用类型-数组

我们知道数据类型分为 基本数据类型 和 引用数据类型,而数组则为引用数据类型的一种

引用数据类型一般存储的是对应空间的地址

public class Test {
    public static void main(String[] args) {
        int[] array = new int[]{10, 20, 30};
    }
}

 array 是引用变量,其内部保存的是数组在堆空间的首地址,而 array 则是在虚拟机栈

上图可以看到,引用类型不直接存储对象本身,而是存储对象在堆空间中的起始地址,通过引用该地址,可以去操作对象在堆空间创建的值

2.1 默认值 null

当我们创建数组时,不确定多大时,可以用 null 代替,它意思为:一个不指向对象的引用

public class Test {
    public static void main(String[] args) {
        int[] array = null;
    }
}

 3. 二维数组

有一句话:二维数组是一个特殊的一维数组

二维数组的结构

类型名[] [] 数组名 = new 类型名[行数] [列数] { 初始化数据 };
public class Test {
    public static void main(String[] args) {
        int[][] array = new int[][]{ {1, 2, 3}, {4, 5, 6}, {7, 8, 9}};
    }
}

只用一张图就可清晰解释二维数组的存储方式

 3.1 遍历二维数组

  • array.length        表示行数
  • array[i].length     表示列数

public class Test {

    public static void printf(int[][] array) {
        for(int i = 0; i < array.length; i++) {
            for(int j = 0; j < array[i].length; j++) {
                System.out.print(array[i][j] + "  ");
            }
            System.out.println();
        }
    }

    public static void main(String[] args) {
        int[][] array = new int[][]{ {1, 2, 3}, {4, 5, 6}, {7, 8, 9}};
        printf(array);
    }
}

 运行结果

 4. 小结

以上就是对数组的了解,具体还需宝子们去实践,如果觉得该博客对你有用的话,希望一键三连,点个关注不迷路,谢谢支持!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2211433.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【最新华为OD机试E卷-支持在线评测】英文输入法(100分)多语言题解-(Python/C/JavaScript/Java/Cpp)

🍭 大家好这里是春秋招笔试突围 ,一枚热爱算法的程序员 💻 ACM金牌🏅️团队 | 大厂实习经历 | 多年算法竞赛经历 ✨ 本系列打算持续跟新华为OD-E/D卷的多语言AC题解 🧩 大部分包含 Python / C / Javascript / Java / Cpp 多语言代码 👏 感谢大家的订阅➕ 和 喜欢�…

AD之Layout设计规则

设计规则&#xff1a; 间距 线宽 过孔 铺铜 其他 1.添加类 这里建立了PWR类&#xff0c;与电源相关的网络 2.间距规则:6mil的成本低 3.线宽规则&#xff1a;PWR的优先级排第一&#xff0c;否则不起作用 4.过孔规则&#xff1a;8mil<大小<12mil 4.铺铜规则

音视频开发:FFmpeg库的使用

文章目录 一、FFmpeg的介绍二、FFmpeg的安装三、FFmpeg的使用1.ffplay&#xff1a;播放音视频2.ffprobe&#xff1a;查看视频信息3.ffmpeg&#xff1a;处理视频(1)格式转换(2)帮助 四、参考资料 一、FFmpeg的介绍 FFmpeg 是使用广泛的多媒体框架&#xff0c;是一个强大的音视频…

LeetCode讲解篇之740. 删除并获得点数

文章目录 题目描述题解思路题解代码题解链接 题目描述 题解思路 首先对于这题我们如果将所有点数装入一个切片f中&#xff0c;该切片f中的i号下标表示所有点数为i的点数之和 那么这题就转换成了打家劫舍这道题&#xff0c;也就是求选择了切片中某个下标的元素后&#xff0c;该…

观察者模式和发布-订阅模式的区别

观察者模式是&#xff0c;当被观察者的数据发生变化时&#xff0c;调用被观察者的 notify 方法&#xff0c;去通知所有观察者执行 update 方法进行更新&#xff1b; 对于发布-订阅模式&#xff0c;首先发布者与订阅者互相并不知道彼此的存在&#xff0c;他们是通过事件中心来进…

Element中el-table组件设置max-height右侧出现空白列的解决方法

之前就出现过这个情况&#xff0c;没理过&#xff0c;因为不影响啥除了不美观...但今天看着实在是难受&#xff0c;怎么都不顺眼(可能是我自己烦躁--) 试了很多网上的方法&#xff0c;都不得行&#xff0c;后面发现了这篇文章&#xff0c;解决了! 感谢&#xff01; Element中t…

微知-Mellanox 网卡和NVIDIA Bluefield DPU如何备份firmware?

某些场合需要从网卡或者DPU上读取网卡的firmware 备份命令&#xff1a; flint -d 06:00.0 ri 1.bin实操&#xff1a; 注意&#xff1a; 有些网卡不支持到处firmware

工具软件分享:11个免费的 android数据恢复应用程序功能分析

在手机上丢失数据是一个很大的错误。但是&#xff0c;在这种情况下&#xff0c;除了惊慌失措之外&#xff0c;最好开始使用android数据恢复应用程序搜索以查找将其取回的方法。您可以检查手机的备份存储以在Android上进行数据恢复&#xff0c;但是如果数据仍然无处可寻&#xf…

elementui时间选择器time-picker返回值不对的问题

1. 问题 天杀的elementui的time-picker&#xff0c;导致我开发的系统出现了一次生产问题&#xff0c;原因竟然是因为组件库的bug&#xff01;直接上截图。 如图&#xff0c;正常情况下&#xff0c;选择时间后&#xff0c;想要得到的值理应是当天的时间&#xff0c;如图是当年…

什么是AI网关?AI网关在企业系统中承担什么角色?

AI 大模型的发展正在推动各行业的增长&#xff0c;据有关报告显示&#xff1a;“未来十年内预计年均增长率将达到37.3%&#xff0c;全球企业预计在2027年之前将在AI领域投入8000亿美元"。这一迅猛发展促使许多企业进行战略转型&#xff0c;技术团队也需要调整其构建、运行…

牛客编程初学者入门训练——BC17 缩短二进制

BC17 缩短二进制 描述 我们处理的整数通常用十进制表示&#xff0c;在计算机内存中是以二进制补码形式存储&#xff0c;但通常二进制表示的整数比较长&#xff0c;为了便于在程序设计过程中理解和处理数据&#xff0c;通常采用八进制和十六进制&#xff0c;缩短了二进制补码表…

Spark高级用法-自定义函数

用户可以根据需求自己封装计算的逻辑&#xff0c;对字段数据进行计算 内置函数&#xff0c;是spark提供的对字段操作的方法 &#xff0c;split(字段) 对字段中的数进行切割&#xff0c;F.sum(字段) 会将该字段下的数据进行求和 实际业务中又能内置函数不满足计算需求&#xff0…

AI如何对产品设计带来更多的可能性?

AI(人工智能)对产品设计带来了广泛而深远的可能性&#xff0c;这些可能性主要体现在以下几个方面 1.创新设计的激发 创意生成:AI能够学习和模仿人类设计师的创作过程&#xff0c;通过深度学习等技术生成全新的、独特的设计概念。这些概念可能源于对大量设计案例的学习和分析&am…

AMD在Advancing AI发布会上发布三大核心硬件产品,挑战英伟达AI芯片市场

美国时间10月10日&#xff0c;AMD在旧金山召开了Advancing AI发布会。 这是老对手英伟达2024 AI Summit 结束后的第三天。与英伟达大会的不同之处在于&#xff0c;英伟达专注于软件方面的更新&#xff0c;而AMD主打“硬”牌。 这一次&#xff0c;他们带来了三款核心硬件产品&…

Python 批量转换 Shapefile 为 GeoJSON

批量转换 Shapefile (.shp) 为 GeoJSON 文件的脚本详解 &#x1f5fa;️&#x1f504; 在地理信息系统&#xff08;GIS&#xff09;和遥感领域&#xff0c;Shapefile&#xff08;.shp&#xff09;格式与GeoJSON格式是两种常用的数据格式。Shapefile 作为矢量数据的标准格式之一…

使用scss生成旋转圆圈

图片 html代码&#xff1a; <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title>…

直播相关04-录制麦克风声音, 通过编程录音

一 通过编程录音 开发录音功能的主要步骤是&#xff1a; 注册设备获取输入格式对象打开设备采集数据释放资源 需要用到的FFmpeg库有4个。 extern "C" { // 设备相关API #include <libavdevice/avdevice.h> // 格式相关API&#xff0c;也就是说&#xff0c;win…

Mysql(2)—SQL语法详解(通俗易懂)

一、关于SQL 1.1 简介 SQL&#xff08;Structured Query Language&#xff0c;结构化查询语言&#xff09;是一种用于管理关系型数据库的标准编程语言。它主要用于数据的查询、插入、更新和删除等操作。SQL最初在1970年代由IBM的研究人员开发&#xff0c;旨在处理关系数据模型…

Python基础常见面试题总结

文章目录 1.深拷贝与浅拷贝2.迭代器3.生成器4.装饰器5.进程、线程、协程6.高阶函数7.魔法方法8.python垃圾回收机制 1.深拷贝与浅拷贝 浅拷贝是对地址的拷贝&#xff0c;只拷贝第一层&#xff0c;第一层改变的时候不会改变&#xff0c;内层改变才会改变。深拷贝是对值的拷贝&a…

【第十六周】回顾线性回归与逻辑回归以及它们的详细推导过程

目录 摘要Abstract1.线性回归1.1.一元线性回归1.1.1.函数凹凸性判断 1.2.多元线性回归1.3.进一步理解梯度下降法 2.逻辑回归2.1.信息论角度推导交叉熵损失函数2.2.概率论角度推导交叉熵损失函数 3.额外阅读&#xff1a;Label Smoothing3.1.One-hot 和 Label Smoothing 的优缺点…