复习笔记第六章 - JAVA中的数组

article/2025/9/29 13:05:56

文章目录

    • 一、数组的创建及初始化
      • 1. 数组创建格式
      • 2. 数组的初始化
      • 3. 数组元素的默认值
    • 二、数组的使用
      • 1. 使用下标访问数组元素
      • 2. 遍历数组
    • 三、数组是引用类型
      • 1. 初始JVM内存分布
        • **区域划分**
      • 2. 基本类型变量和引用类型变量的区别
        • 2.1 基本数据类型作为函数参数
        • 2.2 引用数据类型作为函数参数
        • 3. null值
    • 四、二维数组
      • 1. 如何理解二维数组
      • 2. 二维数组的使用
        • 2.1 二维数组的创建和初始化
        • 2.2 获取数组的长度
        • 2.3 遍历数组
        • 2.4 二维数组元素的默认初始化值
        • 2.5 二维数组的内存解析图
    • 五、数组的常见算法题目
          • 1.数组的创建与元素赋值:
          • 2.针对于数值型的数组:
          • 3.数组的赋值与复制
          • 4.数组元素的反转
          • 5.数组中指定元素的查找:搜索、检索
          • 6.数组的排序算法
    • 六、数组的常见异常
          • 1.数组角标越界异常:ArrayIndexOutOfBoundsException
          • 2.空指针异常:NullPointerException
    • 七、Arrays工具类的使用

数组的定义:一组相同类型元素的集合,在内存中是一块连续的空间(Java中的数组是存放在JVM堆区的),数组中的元素可以通过下标(索引)来访问,数组一旦创建,其长度不可修改。

一、数组的创建及初始化

1. 数组创建格式

type[] 数组名 = new type[长度];

//数组的创建
int[] nums = new int[5];
double[] scores = new double[8];
String[] names = new String[10];

2. 数组的初始化

Java中数组的初始化主要分为静态初始化动态初始化

  • 静态初始化是在创建数组的同时初始化元素值,且数组的长度由初始化列表{ }里面的元素个数决定。
int[] nums = new int[]{1,2,3,4,5};
//可以省略new int[],编译器编译代码时会自动还原。
int[] nums = {1,2,3,4,5};

注意:静态初始化时不能同时指定数组长度且初始列表{ }内的值要与数组元素类型一致

在这里插入图片描述

  • 动态初始化是在创建数组时先指定数组长度,之后再动态的给其元素赋值.
double[] scores = new double[8]; //先开辟数组空间
//后面再动态赋值
scores[0] = 99.8;
scores[1] = 100.0;
scores[2] = 96.0;
.....
  • 静态和动态初始化可以分为两步,但是省略格式不可以。
//静态格式
int[] arr;
arr = new int[]{1,2,3,4,5};//动态格式
int[] arr1;
arr1 = new int[5];
arr1[0] = 1;
arr1[1] = 2;
.....
//省略格式  编译会出错,因为整体初始化只有在声明数组的同时才行。

在这里插入图片描述

3. 数组元素的默认值

如果没有对数组中的元素初始化,数组元素为默认值

  • 如果数组中元素类型为基类类型,默认值为基类类型对应的默认值,见下表:

在这里插入图片描述

  • 如果数组中存储元素类型为引用类型,默认值为null

二、数组的使用

1. 使用下标访问数组元素

数组在内存中是一段连续的空间,空间的编号都是从0开始的,依次递增,该编号称为数组的下标(或索引),数组可以通过下标访问其任意位置的元素。

//打印数组元素
int[] nums = {1,2,3,4,5};
System.out.println(nums[0]); 
System.out.println(nums[1]);
System.out.println(nums[2]);
System.out.println(nums[3]);
System.out.println(nums[4]);
//修改数组元素
nums[0] = 10;

注意事项

  1. 数组是一段连续的内存空间,因此支持随机访问,即通过下标可快速访问数组中任意位置的元素
  2. 下标从0开始,介于[0, N)之间不包含N,N为元素个数,不能越界,否则会报出下标越界异常。

2. 遍历数组

所谓 “遍历” 是指将数组中的所有元素都访问一遍, 访问是指对数组中的元素进行某种操作,比如:取值、打印。

  • 通过使用for循环可以对任意大小的数组遍历。
int[] nums = {10,20,30,40,50};
for(int i = 0; i < nums.length; i++){System.out.println(nums[i]);
}

使用数组名.length可以获取到数组的长度。

  • 使用for-each
int[] nums = {10,20,30,40,50};
for(int x : nums){System.out.println(x);
}

for-each 是 for 循环的另外一种使用方式. 能够更方便的完成对数组的遍历. 可以避免循环条件和更新语句写错.

三、数组是引用类型

1. 初始JVM内存分布

在这里插入图片描述

区域划分

  • 程序计数器 (PC Register): 只是一个很小的空间, 保存下一条执行的指令的地址
  • 虚拟机栈(JVM Stack): 与方法调用相关的一些信息,每个方法在执行时,都会先创建一个栈帧,栈帧中包含 有:局部变量表、操作数栈、动态链接、返回地址以及其他的一些信息,保存的都是与方法执行时相关的一 些信息。比如:局部变量。当方法运行结束后,栈帧就被销毁了,即栈帧中保存的数据也被销毁了。
  • 本地方法栈(Native Method Stack): 本地方法栈与虚拟机栈的作用类似. 只不过保存的内容是Native方法的局 部变量. 在有些版本的 JVM 实现中(例如HotSpot), 本地方法栈和虚拟机栈是一起的
  • 堆(Heap): JVM所管理的最大内存区域. 使用 new 创建的对象都是在堆上保存 (例如前面的 new int[]{1, 2, 3} ),堆是随着程序开始运行时而创建,随着程序的退出而销毁,堆中的数据只要还有在使用,就不会被销毁。
  • 方法区(Method Area): 用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译器编译后的代码等数 据. 方法编译出的的字节码就是保存在这个区域

一切由new关键字创建出来的空间都是分配在堆上面的

2. 基本类型变量和引用类型变量的区别

基本数据类型(如:int、double、char等)创建的变量都称为基本变量,其内存空间存放的是实际的数据值。

引用数据类型(如:String、int[]等)创建的变量一般称为对象的引用,其内存空间存放的不是实际的数据值,而是对象所在空间的地址。

int a = 10;
int b = 20;
int[] arr = new int[12];

内存图:

在这里插入图片描述

通过画内存图可以看出,引用类型变量arr并不直接存放数组的值,而是存放堆区中通过new开辟的一块空间的地址。

2.1 基本数据类型作为函数参数

public static void main(String[] args) {int a = 2;int b = 5;System.out.println("交换前:");System.out.println("a = " + a + ",b = " + b);swapTwoValue(a,b);System.out.println("交换后:");System.out.println("a = " + a + ",b = " + b);
}public static void swapTwoValue(int num1,int num2){int temp = num1;num1 = num2;num2 = temp;
}

在这里插入图片描述

基本数据类型作为函数参数,实参传递的是实际值,称为传值操作,修改形参的值并不会影响到原实参的值。

2.2 引用数据类型作为函数参数

public static void main(String[] args) {int[] arr = new int[5];System.out.println("数组元素填充前:" + Arrays.toString(arr));fillArray(arr,100);System.out.println("数组元素填充后:" + Arrays.toString(arr));
}public static void fillArray(int[] arr,int num){for (int i = 0; i < arr.length; i++) {arr[i] = num;}
}

在这里插入图片描述

引用数据类型作为函数参数,实参传递的是地址值,称为传址操作,修改形参所引用对象的值会影响到实参所引用对象的值。

3. null值

null 在 Java 中表示 “空引用” , 也就是一个不指向对象的引用.

int[] arr = null;
System.out.println(arr[0]);
// 执行结果
Exception in thread "main" java.lang.NullPointerException
at Test.main(Test.java:6)

arr的值为null,即未引用某块内存空间,试图对其进行操作会触发异常。

引用类型数组元素的值默认为null

public static void main(String[] args) {String[] names = new String[5];for (String str:names) {System.out.println(str);}
}

在这里插入图片描述

四、二维数组

1. 如何理解二维数组

数组属于引用数据类型,数组的元素也可以是引用数据类型,一个一维数组arr的元素如果还是一个一维数组类型的,则此数组arr称为二维数组。其实,从数组底层的运行机制来看,其实没有多维数组。

2. 二维数组的使用

2.1 二维数组的创建和初始化

//静态初始化
int[][] arr = new int[][]{{1,2,3},{4,5,6},{7,8,9}};
int[][] arr1 = {{1,2,3},{4,5,6},{7,8,9}};//类型推断//动态初始化
int[][] arr2 = new int[3][3];
arr2[0][0] = 1;
arr2[0][1] = 2;
.....//二维数组的列数可以是不规则的
int[][] arr = new int[][]{{1,2,3},{4,5},{6,7,8,9}};
System.out.println(arr[0].length);//3
System.out.println(arr[1].length);//2
System.out.println(arr[2].length);//4

2.2 获取数组的长度

int[][] arr = new int[][]{{1,2,3},{4,5,6},{7,8,9}};
System.out.println(arr.length);//3
System.out.println(arr[0].length);//3

2.3 遍历数组

int[][] arr = new int[][]{{1,2,3},{4,5,6},{7,8,9}};
for(int i = 0; i < arr.length; i++){for(int j = 0; j < arr[i].length; j++){System.out.print(arr[i][j] + " ");}System.out.println();
}

2.4 二维数组元素的默认初始化值

首先要知道二维数组分为外层数组的元素和内层数组的元素

//例如:
int[][] arr = new int[4][3];
//外层元素:arr[0],arr[1]等
//内层元素:arr[0][0],arr1[1][2]等

数组元素的默认初始化值有两种情况

//初始化方式一:
int[][] arr = new int[4][3];
//外层元素的初始化值为:地址值
//内层元素的初始化值为:该数组内元素的类型 本例为:0
//初始化方式二:
int[][] arr = new int[4][];
//外层元素的初始化值为:null
//内层元素的初始化值为:还没有内层元素的空间,如果调用就会报错

测试不同类型二维数组的默认值

public static void main(String[] args) {int[][] arr = new int[4][3];System.out.println(arr[0]);//[I@1b6d3586  解释:[表示为数组、I表示数组元素类型、@1b6d3586哈希值(地址)System.out.println(arr[0][0]);//0System.out.println(arr); //[[I@4554617c  解释:[[表示为二维数组System.out.println("-------------------");float[][] arr1 = new float[4][3];System.out.println(arr1[0]);//[F@74a14482System.out.println(arr1[0][0]);//0.0System.out.println("-------------------");String[][] arr2 = new String[4][3];System.out.println(arr2[0]);//[Ljava.lang.String;@1540e19d//解释:Ljava.lang.String;为引用类型,引用类型以L开头;结尾System.out.println(arr2[0][0]);//nullSystem.out.println("-------------------");double[][] arr3 = new double[4][];System.out.println(arr3[1]); //null//System.out.println(arr3[1][0]); //NullPointerException
}

2.5 二维数组的内存解析图

在这里插入图片描述

五、数组的常见算法题目

1.数组的创建与元素赋值:

​ 杨辉三角(二维数组)、回形数(二维数组)、6个数,1-30之间随机生成且不重复。

2.针对于数值型的数组:

​ 最大值、最小值、总和、平均数等

3.数组的赋值与复制
4.数组元素的反转
5.数组中指定元素的查找:搜索、检索

​ 5.1 线性查找:
​ 实现思路:通过遍历的方式,一个一个的数据进行比较、查找。
​ 适用性:具有普遍适用性。

​ 5.2 二分法查找:
​ 实现思路:每次比较中间值,折半的方式检索。
​ 适用性:(前提:数组必须有序)

6.数组的排序算法

在这里插入图片描述

​ 理解:
​ 1)衡量排序算法的优劣:时间复杂度、空间复杂度、稳定性

​ 2)排序的分类:内部排序 与 外部排序(需要借助于磁盘)

​ 3)不同排序算法的时间复杂度

在这里插入图片描述

六、数组的常见异常

1.数组角标越界异常:ArrayIndexOutOfBoundsException
public static void main(String[] args) {int[] arr = new int[5];for (int i = 0; i < 6; i++) {arr[i] = i;}
}

在这里插入图片描述

2.空指针异常:NullPointerException
//情况一:
public static void main(String[] args) {int[] arr1 = new int[]{1,2,3};arr1 = null;System.out.println(arr1[0]);
}
//情况二:
public static void main(String[] args) {int[][] arr2 = new int[4][];System.out.println(arr2[0][0]);
}
//情况三:
public static void main(String[] args) {String[] arr3 = new String[]{"AA","BB","CC"};arr3[0] = null;System.out.println(arr3[0].toString());
}

在这里插入图片描述

七、Arrays工具类的使用

Oracle官方提供的数组操作工具类,定义在 java.util 包下,Arrays提供了很多操作数组的方法。

public static void main(String[] args) {//Arrays.sort()、Arrays.toString()int[] arr = {6,2,3,1,8,9,2,1,4,5};Arrays.sort(arr);System.out.println(Arrays.toString(arr));String[] names = {"Tom","Jack","Bob","Emily","Patrick","Ross","Joey"};Arrays.sort(names);System.out.println(Arrays.toString(names));//Arrays.fill();double[] arr1 = new double[10];Arrays.fill(arr1,100.0);System.out.println(Arrays.toString(arr1));//Arrays.binarySearch()int[] arr2 = {1,2,3,4,5,6,7,8,9,10};int index = Arrays.binarySearch(arr2, 100);System.out.println(index);
}

在这里插入图片描述
作者注:此博客为本人学习复习笔记,部分文中图片来自互联网,如有侵权请联系作者删除。


http://chatgpt.dhexx.cn/article/gL1pvxtg.shtml

相关文章

java 删除组中的0元素,Java中如何优雅地删除List中的元素

在工作中的许多场景下,我们都会使用到List这个数据结构,那么同样的有很多场景下需要删除List中的某一个元素或某几个元素,那么我们该如何正确无误地删除List中的元素的,今天我来教大家三种方式。 前提知识准备 for循环的执行顺序 这里借用百度百科的一张图,简明扼要的介绍…

java删除数组中重复元素

id"BAIDU_DUP_fp_iframe" src"https://pos.baidu.com/wh/o.htm?ltr"> > src"http://v3.jiathis.com/code/jiathis_utility.html">     Java SE GXW33 10-08 14:30 等级 28次回复 java删除数组中重复元素 java删除数组中重复…

Nature:Deep Learning 深度学习综述

翻译&#xff1a;https://artificial-intelligence.net.cn/2019/06/05/1559711811/?fromsinglemessage&isappinstalled0 作者&#xff1a;Yann LeCun, Yoshua Bengio ,Geoffrey Hinton 发表及时间&#xff1a;Nature&#xff0c;2015 概念&#xff1a;深度学习允许由多…

深度学习论文学习

1、Swin-Unet: Unet-like Pure Transformer for Medical Image Segmentation 原文 代码 Swin Unet的总体架构如图所示。 编辑 Swin Unet由编码器、瓶颈、解码器和跳跃连接组成。Swin Unet的基本单元是Swin Transformer模块。对于编码器&#xff0c;为了将输入转换为序列嵌入&am…

深度学习论文代码复现——CycleGAN和pix2pix

一&#xff1a;前期代码准备 从GitCode&#xff08;服务器在国内&#xff0c;访问比较快&#xff09;中将开源代码copy下来 地址&#xff1a;mirrors / junyanz / pytorch-cyclegan-and-pix2pix GitCode 也可从github源项目地址中获取&#xff1a;GitHub - junyanz/pytorch…

深度学习论文复习

文章目录 一. 卷积神经网络二. 感受野三. 激活函数四. BN层1. BN层问题2. BN层思想3. BN层训练阶段4. BN层测试阶段 五. AlexNet六. VGG七. ResNet1. 网络加深的问题2. ResNet三个优点&#xff1a; 八. YOLO系列1. YOLO &#xff08;Darknet&#xff09;2. YOLOv2&#xff08;D…

深度学习领域引用量最多的前20篇论文简介

本文来源&#xff1a;全球人工智能 作者&#xff1a;Pedro Lopez&#xff0c;数据科学家&#xff0c;从事金融与商业智能 深度学习是机器学习和统计学交叉领域的一个子集&#xff0c;在过去的几年里得到快速的发展。强大的开源工具以及大数据爆发使其取得令人惊讶的突破进展。本…

2019年最新十篇「深度学习领域综述」论文

1、A guide to deep learning in healthcare&#xff08;医疗深度学习技术指南&#xff09; Google 斯坦福 Nature Medicine 作者&#xff1a;Andre Esteva, Alexandre Robicquet, Bharath Ramsundar, Volodymyr Kuleshov, Mark DePristo, Katherine Chou, Claire Cui, Greg …

【深度学习】2022年最值得关注的十篇论文,你都看了吗?来卷来学习

选自Ahead of AI 作者&#xff1a;Sebastian Raschka 机器之心编译 编辑&#xff1a;王强、蛋酱 年关将至&#xff0c;威斯康星大学助理教授 Sebastian Raschka 盘点了 2022 年他最看好的十大论文。 2022 年 1 月&#xff0c;扩散模型第一次吸引了我的眼球。当时我判断到将会有…

10篇论文带你入门深度学习图像分类(附下载)

来源&#xff1a;计算机视觉联盟 本文约7600字&#xff0c;建议阅读10分钟。 本文将介绍10篇最佳论文供初学者阅读。 前言 计算机视觉是将图像和视频转换成机器可理解的信号的主题。利用这些信号&#xff0c;程序员可以基于这种高级理解来进一步控制机器的行为。在许多计算机视…

机器学习和深度学习引用量最高的20篇论文(2014-2017)

机器学习和深度学习的研究进展正深刻变革着人类的技术&#xff0c;本文列出了自 2014 年以来这两个领域发表的最重要&#xff08;被引用次数最多&#xff09;的 20 篇科学论文&#xff0c;以飨读者。 机器学习&#xff0c;尤其是其子领域深度学习&#xff0c;在近些年来取得了许…

综述 | 近年来深度学习的重要研究成果(附PDF)

来源&#xff1a;机器之心 本文约1万字&#xff0c;建议阅读15分钟。 本文列举出了近年来深度学习的重要研究成果&#xff0c;从方法、架构&#xff0c;以及正则化、优化技术方面进行概述。 这篇综述论文列举出了近年来深度学习的重要研究成果&#xff0c;从方法、架构&#xf…

2023年2月的十篇深度学习论文推荐

本月的论文包括语言模型、扩散模型、音乐生成、多模态等主题。 1、MusicLM: Generating Music From TextPage https://arxiv.org/abs/2301.11325 By Andrea Agostinelli, Timeo I. Denk, et al. 扩散模型和自回归离散模型都在生成音乐/音频显示出令人印象深刻的性能。 与最…

深度学习研究综述

本文分为四章。 第一章 神经网络的发展 深度学习&#xff08;deep learning&#xff09;作为机器学习算法中的一个新兴技术&#xff0c;其动机在于建立&#xff0c;模拟人脑进行分析学习的神经网络。 深度学习的本质是对观察数据进行分层特征表示&#xff0c;实现将低级特征进…

如何快速入门深度学习写论文?

原文作者&#xff1a;月来客栈 https://www.zhihu.com/people/the_lastest 最快的方式&#xff1a; 第一&#xff0c;选择一篇有代码的论文&#xff0c;记住一定要有代码&#xff1b; 第二&#xff0c;大致弄清楚论文里所提出算法的思想原理&#xff1b; 第三&#xff…

2021年3月四篇深度学习论文推荐

这是Machine-Learning-Collage系列&#xff0c;每隔一周作者都会编写一个本周论文的幻灯片摘要。每月底所有的幻灯片画都会被集中到一个总结文章中。作者希望给读者一个直观和直观的一些最酷的趋势。以下是作者在2021年3月读到的四篇最喜欢的论文&#xff0c;以及为什么我相信它…

深度学习论文《Deep Learning》

论文《Deep Learning》 (深度学习) 作者&#xff1a;Yann Lecun, Yoshua Bengio, Geoffery Hinton 单位&#xff1a; FAIR&#xff0c; NYU&#xff0c; UMontreal&#xff0c; Utoronto&#xff0c; Google 发表会议及时间&#xff1a;《Nature》杂志 1、论文作者简介 2019…

2022 年 1 月推荐阅读的四篇深度学习论文

自举元学习到深度学习的时间序列预测&#xff0c;外推与泛化之间的关系与 Ridge Rider 探索多样化最优 ‘Bootstrapped Meta-Learning’ Flennerhag et al. (2021) | &#x1f4dd; https://arxiv.org/pdf/2109.04504.pdf 元学习算法旨在自动发现归纳偏差&#xff0c;这允许…

深度学习9篇论文

Introduction 卷积神经网络CNN&#xff0c;虽然它听起来就像是生物学、数学和计算机的奇怪混杂产物&#xff0c;但在近些年的机器视觉领域&#xff0c;它是最具影响力的创新结果。随着Alex Krizhevsky开始使用神经网络&#xff0c;将分类错误率由26%降到15%并赢得2012年度Image…

2020年最新Spark企业级面试题【上】

前言 现在距离2021年还有不到一个月的时间了&#xff0c;是不是有的小伙明年不知该怎么复习spark&#xff0c;以及不知道该备战企业中会问到那些问题。好今天他来了总结了20个企业中经常被问到的面题以及会附带一些笔试题哦&#xff0c;编写不易建议收藏。 一、 Spark 有几种…