百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

二十、Java数组(java数组详解)

wptr33 2025-03-19 03:10 8 浏览

数组的基本概念

数组是一种可以存储多个相同类型数据的数据结构,这些数据在内存中是连续存储的。数组中的每个数据项称为数组的元素,每个元素都可以通过索引来访问。Java中的数组属于对象类型,数组中的可以是基本数据类型,也可以是对象类型。

数组的声明与创建

数组的声明方式:

序号

语法

说明

1

数据类型 数组名[ ]

数组声明并没有为数组元素分配内存。

只有初始化后,才能访问数组的元素。

2

数据类型[ ] 数组名

数组的初始化方式:

序号

初始化方式

说明

1

静态初始化

在定义数组的同时就为数组元素分配空间并赋值

2

动态初始化

使用运算符new为数组分配空间

数组的声明和创建方式:

声明与创建

案例

声明,分配空间,并赋值

int[] arr = new int[]{1, 2, 3, 4, 5};

int[] arr = {1, 2, 3, 4, 5};

声明指定元素个数

int[] arr = new int[5];

声明,然后再分配空间并赋值

int[] arr;

arr = new int[]{1, 2, 3, 4, 5}

两种常用的声明和创建数组方式:

方式一:声明并分配空间:

int[] myArray = new int[5]; // 创建一个整型数组,包含5个元素

上述代码创建了一个整型数组myArray,包含5个元素。数组的元素默认初始化为0(对于基本数据类型)或null(对于对象类型)。

方式二:使用数组初始化器在声明时直接初始化数组:

int[] myArray = {1, 2, 3, 4, 5}; // 使用数组初始化器创建并初始化数组

数组的使用

通过数组的索引可以访问和修改数组中的元素。数组的索引从0开始,因此一个包含5个元素的数组的索引范围是0到4。

示例:

public class ArrayExample {  
    public static void main(String[] args) {  
        int[] myArray = new int[5]; // 创建一个整型数组,包含5个元素  
          
        // 为数组元素赋值  
        myArray[0] = 10;  
        myArray[1] = 20;  
        myArray[2] = 30;  
        myArray[3] = 40;  
        myArray[4] = 50;  
          
        // 访问并打印数组元素的值  
        for (int i = 0; i < myArray.length; i++) {  
            System.out.println("Element at index " + i + " is " + myArray[i]);  
        }  
    }  
}


多维数组

多维数组,即数组的数组。多维数组常用于表示表格或矩阵等数据。

二维数组的示例:

int[][] matrix = new int[3][3]; // 创建一个3x3的二维整型数组  
  
// 为二维数组赋值  
matrix[0][0] = 1;  
matrix[0][1] = 2;  
matrix[0][2] = 3;  
matrix[1][0] = 4;  
matrix[1][1] = 5;  
matrix[1][2] = 6;  
matrix[2][0] = 7;  
matrix[2][1] = 8;  
matrix[2][2] = 9;  
  
// 访问并打印二维数组的元素值  
for (int i = 0; i < matrix.length; i++) {  
    for (int j = 0; j < matrix[i].length; j++) {  
        System.out.print(matrix[i][j] + " ");  
    }  
    System.out.println(); // 换行打印每一行元素值  
}


总结与拓展思考:


描述

性能

数组在内存中是连续存储的,可以通过简单的数学计算得到元素的内存地址,这使得访问数组元素非常快速,。

空间效率

数组的大小是固定的,一旦分配了内存空间,就不能改变。

越界异常

越界访问数组元素,会抛出数组越界
ArrayIndexOutOfBoundsException异常

空指针异常

对于对象数组,如果尝试访问一个未初始化的元素,会抛出空指针NullPointerException异常。

多维数组

多维数组常用于表示复杂的数据结构,如矩阵或图像数据。

嵌套循环

在处理多维数组时,通常需要使用嵌套循环来遍历和操作数组元素。要注意循环变量的范围和步长,以避免越界或遗漏元素。

算法与

数据结构

数组作为最基本的数据结构之一,与许多算法和数据结构密切相关。例如,排序算法(如快速排序、归并排序等)和搜索算法(如二分搜索)通常都基于数组。

相关推荐

每天一个编程技巧!掌握这7个神技,代码效率飙升200%

“同事6点下班,你却为改BUG加班到凌晨?不是你不努力,而是没掌握‘偷懒’的艺术!本文揭秘谷歌工程师私藏的7个编程神技,每天1分钟,让你的代码从‘能用’变‘逆天’。文末附《Python高效代码模板》,...

Git重置到某个历史节点(Sourcetree工具)

前言Sourcetree回滚提交和重置当前分支到此次提交的区别?回滚提交是指将改动的代码提交到本地仓库,但未推送到远端仓库的时候。...

git工作区、暂存区、本地仓库、远程仓库的区别和联系

很多程序员天天写代码,提交代码,拉取代码,对git操作非常熟练,但是对git的原理并不甚了解,借助豆包AI,写个文章总结一下。Git的四个核心区域(工作区、暂存区、本地仓库、远程仓库)是版本控制的核...

解锁人生新剧本的密钥:学会让往事退场

开篇:敦煌莫高窟的千年启示在莫高窟321窟的《降魔变》壁画前,讲解员指着斑驳色彩说:"画师刻意保留了历代修补痕迹,因为真正的传承不是定格,而是流动。"就像我们的人生剧本,精彩章节永远...

Reset local repository branch to be just like remote repository HEAD

技术背景在使用Git进行版本控制时,有时会遇到本地分支与远程分支不一致的情况。可能是因为误操作、多人协作时远程分支被更新等原因。这时就需要将本地分支重置为与远程分支的...

Git恢复至之前版本(git恢复到pull之前的版本)

让程序回到提交前的样子:两种解决方法:回退(reset)、反做(revert)方法一:gitreset...

如何将文件重置或回退到特定版本(怎么让文件回到初始状态)

技术背景在使用Git进行版本控制时,经常会遇到需要将文件回退到特定版本的情况。可能是因为当前版本出现了错误,或者想要恢复到之前某个稳定的版本。Git提供了多种方式来实现这一需求。...

git如何正确回滚代码(git命令回滚代码)

方法一,删除远程分支再提交①首先两步保证当前工作区是干净的,并且和远程分支代码一致$gitcocurrentBranch$gitpullorigincurrentBranch$gi...

[git]撤销的相关命令:reset、revert、checkout

基本概念如果不清晰上面的四个概念,请查看廖老师的git教程这里我多说几句:最开始我使用git的时候,我并不明白我为什么写完代码要用git的一些列指令把我的修改存起来。后来用多了,也就明白了为什么。gi...

利用shell脚本将Mysql错误日志保存到数据库中

说明:利用shell脚本将MYSQL的错误日志提取并保存到数据库中步骤:1)创建数据库,创建表CreatedatabaseMysqlCenter;UseMysqlCenter;CREATET...

MySQL 9.3 引入增强的JavaScript支持

MySQL,这一广泛采用的开源关系型数据库管理系统(RDBMS),发布了其9.x系列的第三个更新版本——9.3版,带来了多项新功能。...

python 连接 mysql 数据库(python连接MySQL数据库案例)

用PyMySQL包来连接Python和MySQL。在使用前需要先通过pip来安装PyMySQL包:在windows系统中打开cmd,输入pipinstallPyMySQL ...

mysql导入导出命令(mysql 导入命令)

mysql导入导出命令mysqldump命令的输入是在bin目录下.1.导出整个数据库  mysqldump-u用户名-p数据库名>导出的文件名  mysqldump-uw...

MySQL-SQL介绍(mysql sqlyog)

介绍结构化查询语言是高级的非过程化编程语言,允许用户在高层数据结构上工作。它不要求用户指定对数据的存放方法,也不需要用户了解具体的数据存放方式,所以具有完全不同底层结构的不同数据库系统,可以使用相同...

MySQL 误删除数据恢复全攻略:基于 Binlog 的实战指南

在MySQL的世界里,二进制日志(Binlog)就是我们的"时光机"。它默默记录着数据库的每一个重要变更,就像一位忠实的史官,为我们在数据灾难中提供最后的救命稻草。本文将带您深入掌握如...