Java数组:一维数组、二维数组、Arrays

文章目录

    • 1、一维数组
      • 1.1 数组概念
      • 1.2 数组的声明
      • 1.3 数组的静态初始化
      • 1.4 数组的动态初始化
      • 1.5 地址值
      • 1.6 数组元素访问
      • 1.7 索引
      • 1.8 数组的遍历
      • 1.9 数组两种初始化方式的区别
    • 2、二维数组
      • 2.1 二维数组的声明
      • 2.2 二维数组的静态初始化
      • 2.3 二维数组的动态初始化
      • 2.4 二维数组的遍历
    • 3、操作数组的工具类Arrays
      • 3.1 基本使用
      • 3.2 重写排序方法

1、一维数组

1.1 数组概念

数组指的是一种容器,可以同来存储同种数据类型的多个值。但是数组容器在存储数据的时候,需要结合隐式转换考虑。

比如:定义了一个int类型的数组。那么boolean。double类型的数据是不能存到这个数组中的,但是byte类型,short类型,int类型的数据是可以存到这个数组里面的。

建议:容器的类,和存储的数据类型保持一致。

举例:

  • 整数1 2 3 4 56 就可以使用int类型的数组来存储。
  • 小数1.1 1.2 1.3 1.4 就可以使用double类型的数组来存储。
  • 字符串"aaa" “bbb” “ccc” 就可以使用String类型的数组来存储。

1.2 数组的声明

格式一(推荐):

数据类型 [] 数组名
int [] array;

格式二:

数据类型  数组名 []
int array [];
  • 数据类型:限定了数组以后能存什么类型的数据。
  • 方括号:表示现在定义的是一个数组。
  • 数组名:就是一个名字而已,方便以后使用。

1.3 数组的静态初始化

完整格式:

数据类型[] 数组名 = new 数据类型[]{元素1,元素2,元素3,元素4...};
int[] arr = new int[]{11,22,33};
double[] arr = new double[]{1.1,1.2,1.3};
  • 数据类型:限定了数组以后能存什么类型的数据。
  • 方括号:表示现在定义的是一个数组。
  • 数组名:其实就是名字而已,方便以后使用,在起名字的时候遵循小驼峰命名法。
  • new:就是给数组在内存中开辟了一个空间。
  • 数据类型:限定了数组以后能存什么类型的数据,前面和后面的数据类型一定要保持一致。
  • 方括号:表示现在定义的是一个数组。
  • 大括号:表示数组里面的元素。元素也就是存入到数组中的数据。
  • 数组一旦创建之后,长度不能发生变化。

简化格式:

数据类型[] 数组名 = {元素1,元素2,元素3,元素4...};
int[] array = {1,2,3,4,5};
double[] array = {1.1,1.2,1.3};

1.4 数组的动态初始化

不明确具体的数据,推荐使用动态初始化,默认初始值,后序再由代码设置实际的值。

格式:

数据类型[] 数组名 = new 数据类型[数组的长度];
//1.定义一个数组,存3个人的年龄,年龄未知
int[] agesArr = new int[3];

//2.定义一个数组,存班级10名学生的考试成绩,考试成绩暂时未知,考完才知道。
int[] scoresArr = new int[10];

数组的默认初始化值:

  • 整数类型:0
  • 小数类型:0.0
  • 布尔类型:false
  • 字符类型:‘\u0000’
  • 引用类型:null

1.5 地址值

int[] arr = {1,2,3,4,5};
System.out.println(arr);//[I@6d03e736

double[] arr2 = {1.1,2.2,3.3};
System.out.println(arr2);//[D@568db2f2

打印数组的时候,实际出现的是数组的地址值。数组的地址值表示数组在内存中的位置。

以[I@6d03e736为例:

  • [ :表示现在打印的是一个数组。
  • I:表示现在打印的数组是int类型的。
  • @:仅仅是一个间隔符号而已。
  • 6d03e736:就是数组在内存中真正的地址值。(十六进制的)

但是,我们习惯性会把[I@6d03e736这个整体称之为数组的地址值。地址值对于我们来说,作用不大,简单了解。

1.6 数组元素访问

格式:

数组名[索引];
  • 获取数组中对应索引上的值

  • 修改数组中对应索引上的值,一旦修改之后,原来的值就会被覆盖了。

代码示例:

public class ArrDemo2 {
    /*
        数组中元素访问的格式:
                数组名[索引];
         作用:
            1.获取指定索引上对应的元素
            2.修改指定索引上对应的元素
    */
    public static void main(String[] args) {
       int[] arr = {1,2,3,4,5};
       //需求1:获取arr数组中,3索引上的值
        int number = arr[3];
        System.out.println(number);
        System.out.println(arr[3]);

       //需求2:将arr数组中,3索引上的值修改为10
            arr[3] = 10;
        System.out.println("修改之后为:" + arr[3]);
    }
}

1.7 索引

数组索引也叫角标、下标,就是数组容器中每一个小格子对应的编号。索引的特点:

  • 索引一定是从0开始的。
  • 连续不间断。
  • 逐个+1增长。

1.8 数组的遍历

遍历:就是把数组里面所有的内容一个一个全部取出来。

数组的长度:数组名.length;

通用代码:

for(int i = 0; i < arr.length; i++){
    //在循环的过程中,i依次表示数组中的每一个索引
    sout(arr[i]);//就可以把数组里面的每一个元素都获取出来,并打印在控制台上了。
}

1.9 数组两种初始化方式的区别

静态初始化:int[] arr = {1,2,3,4,5};
动态初始化:int[] arr = new int[3];

静态初始化:手动指定数组的元素,系统会根据元素的个数,计算出数组的长度。
动态初始化:手动指定数组长度,由系统给出默认初始化值。

使用场景:只明确元素个数,但是不明确具体的数据,推荐使用动态初始化。已经明确了要操作的所有数据,推荐使用静态初始化。

举例:

  • 使用数组来存储键盘录入的5个整数。

    int[] arr = new int[5];
    
  • 将全班的学生成绩存入数组中,已知学生成绩为:66,77,88,99,100

    int[] arr = new int[5];
    arr[0] = 66;
    arr[1] = 77;
    

    虽然可以实现,但是太麻烦了,建议使用静态初始化:int[] arr = {66,77,88,99,100};

2、二维数组

2.1 二维数组的声明

数据类型[][] 数组名;
int[][] array;

这只是声明了一个数组变量,而没有分配内存空间或初始化数组。在使用数组之前,需要使用 new 关键字为数组分配内存,并指定数组的行数和列数(即初始化),如:

int[][] array;
array = new int[3][4];

2.2 二维数组的静态初始化

完整格式:

数据类型[][] 数组名 = new 数据类型[][]{{元素1,元素2},{元素1,元素2}}
int[][] arr = new int[][]{{1, 2, 3}, {4, 5, 6, 7, 8}};

简化格式:

数据类型[][] 数组名 = {{元素1,元素2},{元素1,元素2}}
int[][] arr = {{1, 2, 3},{4, 5, 6, 7, 8}};

2.3 二维数组的动态初始化

不明确具体的数据,推荐使用动态初始化,默认初始值,后序再由代码设置实际的值。

格式:

数据类型[][] 数组名 = new 数据类型[m][n]  
int[][] arr = new int[3][3];

m为二维数组中一维数组的数量,n表示每个一维数组的长度。

特殊情况:省略第二维大小

int[][] array = new int[3][];
array[0] = new int[2];
array[1] = new int[3];
array[2] = new int[4];

在这个例子中,array 是一个包含3行的二维数组,但每一行的列数不同。通过在第二维中使用不同的 new int[] 语句,为每一行分配了不同长度的数组。

2.4 二维数组的遍历

嵌套的for循环:

int[][] array = {
    {1, 2, 3},
    {4, 5, 6},
    {7, 8, 9}
};

for (int i = 0; i < array.length; i++) {
    for (int j = 0; j < array[i].length; j++) {
        int element = array[i][j];
        // 对数组中的元素进行操作
        System.out.print(element + " ");
    }
    System.out.println(); // 换行
}

image-20231230181443257

增强型for循环:

int[][] array = {
    {1, 2, 3},
    {4, 5, 6},
    {7, 8, 9}
};

for (int[] row : array) {
    for (int element : row) {
        // 对数组中的元素进行操作
        System.out.print(element + " ");
    }
    System.out.println(); // 换行
}

image-20231230181444815

3、操作数组的工具类Arrays

3.1 基本使用

  • tostring:将数组变成字符串
  • binarySearch:二分查找发查找元素
  • copyOf:拷贝数组
  • copyOfRange:拷贝数组(指定范围)
  • fill:填充数组,会覆盖原来的元素
  • sort:排序,默认情况下,给基本数据类型进行升序排列,底层使用的是快速排序
public class ArraysDemo01 {
    public static void main(String[] args) {
        //tostring: 将数组变成字符串
        System.out.println("-----------------toString--------------------------");
        int[] arr = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
        System.out.println(Arrays.toString(arr));

        /**
         * binarySearch:二分查找发查找元素
         * 细节1:二分查找的前提:数组中的元素必须是有序,且数组元素必须时升序
         * 细节2:如果查找的元素时存在的,返回的是真实的索引,如果查找的元素不存在,返回的是 ( -插入点-1 ),插入点是指当前的元素应该在数组中的什么位置
         */
        System.out.println("-----------------binarySearch--------------------------");
        System.out.println(Arrays.binarySearch(arr, 10));//9
        System.out.println(Arrays.binarySearch(arr, 2));//1
        System.out.println(Arrays.binarySearch(arr, 20));//-11


        /**
         * copyOf:拷贝数组
         * 参数一:老数组
         * 参数二:新数组的长度
         * 返回值:新数组
         *
         * 如果新数组小于老数组的长度,会部分拷贝
         * 如果新数组等于老数组的长度,会完全拷贝
         * 如果新数组大于老数组的长度,会补上默认初始值
         */
        System.out.println("-----------------copyOf--------------------------");
        int[] newArr1 = Arrays.copyOf(arr, arr.length);
        System.out.println(Arrays.toString(newArr1));

        //copyOfRange:拷贝数组(指定范围)
        //细节:包头不包尾,包左不包右
        System.out.println("-----------------copyOfRange--------------------------");
        int[] newArr2 = Arrays.copyOfRange(arr, 0, 9);//拷贝了索引为0~8的数据
        System.out.println(Arrays.toString(newArr2));

        //fill:填充数组,会覆盖原来的元素
        System.out.println("-----------------fill--------------------------");
        Arrays.fill(arr, 20);
        System.out.println(Arrays.toString(arr));

        //sort:排序,默认情况下,给基本数据类型进行升序排列,底层使用的是快速排序
        System.out.println("-----------------sort--------------------------");
        int[] arr2 = {10, 2, 5, 1, 4, 3, 6, 7, 8, 9};
        Arrays.sort(arr2);
        System.out.println(Arrays.toString(arr2));
    }
}

image-20231227110933955

3.2 重写排序方法

public static void sort(要排序的数组,排序规则) 按照指定的规则排序

  • 只能给引用数据类型的数组进行排序
  • 如果数组是基本数据类型,需要变成对应的包装类

底层原理:

  • 利用插入排序 + 二分查找的方式进行排序的。
  • 默认把0索引的数据当做是有序的序列,1索引到最后认为是无序的序列。
  • 遍历无序的序列得到里面的每一个元素,假设当前遍历得到的元素是A元素
  • 把A往有序序列中进行插入,在插入的时候,是利用二分查找确定A元素的插入点。
  • 拿着A元素,跟插入点的元素进行比较,比较的规则就是compare方法的方法体
  • 如果方法的返回值是负数,拿着A继续跟前面的数据进行比较
  • 如果方法的返回值是正数,拿着A继续跟后面的数据进行比较
  • 如果方法的返回值是0,也拿着A跟后面的数据进行比较
  • 直到能确定A的最终位置为止。

compare方法的形式参数:

  • 参数一 o1: 表示在无序序列中,遍历得到的每一个元素

  • 参数二 o2: 有序序列中的元素

  • 返回值:

    • 负数:表示当前要插入的元素是小的,放在前面

    • 正数:表示当前要插入的元素是大的,放在后面

    • 0: 表示当前要插入的元素跟现在的元素比是一样的们也会放在后面

    • 简单理解
      return o1 - o2; //升序排序
      return o2 - o1; //降序排序

代码示例:

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

        Integer[] arr3 = {10, 2, 5, 1, 4, 3, 6, 7, 8, 9};
        Arrays.sort(arr3, new Comparator<Integer>() {
            @Override
            public int compare(Integer o1, Integer o2) {
                System.out.println("=============");
                System.out.println("o1:" + o1);
                System.out.println("o2:" + o2);
                System.out.println(o1 - o2);
                //return o1 - o2;   //升序排序
                return o2 - o1;     //降序排序
            }
        });
        System.out.println(Arrays.toString(arr3));
    }
}

输出

=============
o1:2
o2:10
-8
=============
o1:5
o2:2
3
=============
o1:5
o2:2
3
=============
o1:5
o2:10
-5
=============
o1:1
o2:5
-4
=============
o1:1
o2:2
-1
=============
o1:4
o2:2
2
=============
o1:4
o2:5
-1
=============
o1:3
o2:4
-1
=============
o1:3
o2:1
2
=============
o1:3
o2:2
1
=============
o1:6
o2:3
3
=============
o1:6
o2:5
1
=============
o1:6
o2:10
-4
=============
o1:7
o2:4
3
=============
o1:7
o2:6
1
=============
o1:7
o2:10
-3
=============
o1:8
o2:4
4
=============
o1:8
o2:6
2
=============
o1:8
o2:7
1
=============
o1:8
o2:10
-2
=============
o1:9
o2:5
4
=============
o1:9
o2:7
2
=============
o1:9
o2:8
1
=============
o1:9
o2:10
-1
[10, 9, 8, 7, 6, 5, 4, 3, 2, 1]

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

扩散模型: Diffusion Model概念讲解

Diffusion Model 课件视频前向扩散过程 在原始图像中逐步添加高斯分布随机噪声,直到最后得到完全噪声的图像。 反向降噪过程 逐步去除噪声图中的噪声,得到最后原图。 根据噪声图和时间步得到预测的噪声,然后噪声图减去噪声得到原始图 噪声预测的标签来自于前向扩散过程中添加…

TSINGSEE青犀智能分析网关V4在智慧园区车辆违停检测场景中的应用

一、背景与需求 园区作为企业办公、生产制造的重要场所&#xff0c;主要道路车辆违停等违规行为会对园区的安全造成隐患&#xff0c;并且在上下班高峰期内&#xff0c;由于发现不及时&#xff0c;车辆违停行为会造成出入口拥堵现象&#xff0c;这也成为园区管理的棘手问题。为了…

胡圆圆的暑期实习经验分享

背景 实验室一般是在研究生二年级的时候会放实习&#xff0c;在以后的日子就是自己完成毕业工作要求&#xff0c;基本上不再涉及实验室的活了&#xff0c;目前是一月份也是开始准备暑期实习的好时间。实验室每年这个时候都会有学长学姐组织暑期实习经验分享&#xff0c;本着不…

uniappVue3版本中组件生命周期和页面生命周期的详细介绍

一、什么是生命周期&#xff1f; 生命周期有多重叫法&#xff0c;有叫生命周期函数的&#xff0c;也有叫生命周期钩子的&#xff0c;还有钩子函数的&#xff0c;其实都是代表&#xff0c;在 Vue 实例创建、更新和销毁的不同阶段触发的一组钩子函数&#xff0c;这些生命周期函数…

STM32F407-14.3.10-表73具有有断路功能的互补通道OCx和OCxN的输出控制位-00x00-11x11(总结)

如上表73所示&#xff0c;主输出使能&#xff08;MOE0&#xff09;的8种OCx与OCxN的输出状态及波形图&#xff0c;已经单独整理输出8篇文章&#xff0c;方便需要时单独回查。 根据表73可得以下结论 1、从00x00~01x00的前5种状态的OCx与OCxN的引脚电平全由GPIO端口的上下拉决定…

Java序列化篇----第一篇

系列文章目录 文章目录 系列文章目录前言一、什么是java序列化,如何实现java序列化?二、保存(持久化)对象及其状态到内存或者磁盘三、序列化对象以字节数组保持-静态成员不保存四、序列化用户远程对象传输前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,…

1389 蓝桥杯 二分查找数组元素 简单

1389 蓝桥杯 二分查找数组元素 简单 //C风格解法1&#xff0c;lower_bound(),通过率100% //利用二分查找的方法在有序的数组中查找&#xff0c;左闭右开 #include <bits/stdc.h> using namespace std;int main(){int data[200];for(int i 0 ; i < 200 ; i) data[i] …

回首2023,期待2024!

2023&#xff0c;在改变中到来 2023年1月1日&#xff0c;我从成都冷清的学校回到了哈尔滨的老家&#xff0c;开始了保研之前的最后一个寒假 当时的目标是将之前的科研理论转化为实际&#xff0c;生产出一篇sci&#xff0c;助力保研加分 星移斗转&#xff0c;事与愿违&#x…

贯穿设计模式-责任链模式

样例代码 涉及到的项目样例代码均可以从https://github.com/WeiXiao-Hyy/Design-Patterns.git获取 需求 实时地&#xff0c;根据city&#xff0c;sex&#xff0c;product字段进行业务投放&#xff0c;比如&#xff1a;北京的男生&#xff1b;四川的电脑等等 → 责任链模式&…

React之useRef hook

介绍 useRef是react的自定义hook&#xff0c;它用来引用一个不需要渲染的值。这篇文章会介绍useRef的简单用法。 使用场景 1.实现节流 通过useRef实现节流功能&#xff0c;在限制时间内多次提交&#xff0c;已第一次提交为准。 useThrottle.jsx import {useEffect, useRef,…

【gRPC学习】使用go学习gRPC

个人博客:Sekyoro的博客小屋 个人网站:Proanimer的个人网站 RPC是远程调用,而google实现了grpc比较方便地实现了远程调用,gRPC是一个现代的开源远程过程调用(RPC)框架 概念介绍 在gRPC中&#xff0c;客户端应用程序可以直接调用另一台计算机上的服务器应用程序上的方法&#…

Generator - JavaScript的异步颠覆者

&#x1f9d1;‍&#x1f393; 个人主页&#xff1a;《爱蹦跶的大A阿》 &#x1f525;当前正在更新专栏&#xff1a;《VUE》 、《JavaScript保姆级教程》、《krpano》 ​ ​ 目录 ✨ 前言 什么是Generator 生成器函数的执行流程控制 异步编程应用 ✨ 结语 ✨ 前言 Java…

滑动窗口协议仿真(2024)

1.题目描述 滑动窗口协议以基于分组的数据传输协议为特征&#xff0c;该协议适用于在数据链路层以及传输层中对按 顺序传送分组的可靠性要求较高的环境。在长管道传输过程&#xff08;特别是无线环境&#xff09;中&#xff0c;相应的滑动窗口 协议可实现高效的重传恢复。附录 …

[Redis实战]分布式锁

四、分布式锁 4.1 基本原理和实现方式对比 分布式锁&#xff1a;满足分布式系统或集群模式下多进程可见并且互斥的锁。 分布式锁的核心思想就是让大家都使用同一把锁&#xff0c;只要大家使用的是同一把锁&#xff0c;那么我们就能锁住线程&#xff0c;不让线程进行&#xf…

浏览器的渲染流程

✨专栏介绍 在当今数字化时代&#xff0c;Web应用程序已经成为了人们生活和工作中不可或缺的一部分。而要构建出令人印象深刻且功能强大的Web应用程序&#xff0c;就需要掌握一系列前端技术。前端技术涵盖了HTML、CSS和JavaScript等核心技术&#xff0c;以及各种框架、库和工具…

基于SpringBoot的MusiQ音乐网站

目录 前言 开发环境以及工具 项目功能 用户&#xff1a; 后台&#xff1a; 设计详情​编辑 登陆页面 后台管理页面 首页 视频展示 源码获取 前言 本项目是一个基于IDEA和Java语言开基于SpringBoot的MusiQ音乐网站。应用包含管理端&#xff0c;教师端&#xff0c;学生…

Spring见解 5 Spring整合MyBatis

6.Spring整合MyBatis 6.1.创建工程 6.1.1.pom.xml <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation…

YOLOv5改进 | 损失篇 | VarifocalLoss密集检测专用损失函数 (VFLoss,论文一比一复现)

一、本文介绍 本文给大家带来的是损失函数改进VFLoss损失函数,VFL是一种为密集目标检测器训练预测IoU-aware Classification Scores(IACS)的损失函数,我经过官方的版本将其集成在我们的YOLOv8的损失函数使用上,其中有很多使用的小细节(否则按照官方的版本使用根本拟合不了…

SpringBoot学习(六)-SpringBoot整合Shiro

12、Shiro 12.1概述 12.1.1简介 Apache Shiro是一个强大且易用的Java安全框架 可以完成身份验证、授权、密码和会话管理 Shiro 不仅可以用在 JavaSE 环境中&#xff0c;也可以用在 JavaEE 环境中 官网&#xff1a; http://shiro.apache.org/ 12.1.2 功能 Authentication…

开源加解密库之GmSSL

一、简介 GmSSL是由北京大学自主开发的国产商用密码开源库&#xff0c;实现了对国密算法、标准和安全通信协议的全面功能覆盖&#xff0c;支持包括移动端在内的主流操作系统和处理器&#xff0c;支持密码钥匙、密码卡等典型国产密码硬件&#xff0c;提供功能丰富的命令行工具及…