JAVA数组的定义及用法

JAVA数组的定义及用法

大家好,又见面了,我是全栈君,祝每个程序员都可以多学几门语言。

数组是有序数据的集合,数组中的每一个元素具有同样的数组名和下标来唯一地确定数组中的元素。

 

1. 一维数组

 

1.1 一维数组的定义

 

type arrayName[];

type[] arrayName;

 

当中类型(type)能够为Java中随意的数据类型,包含简单类型组合类型,数组名arrayName为一个合法的标识符,[]指明该变量是一个数组类型变量。

 

另外一种形式对C++开发人员可能认为非常奇怪,只是对JAVA或C#这种开发语言来说,另外一种形式可能更直观,由于这里定义的仅仅是个变量而已,系统并未对事实上例化,仅仅需指明变量的类型就可以,也不需在[]指定数组大小。(第一种形式是不是仅仅是为了兼容曾经的习惯,毕竟C语言的影响太大了?)

 

比如:

int intArray[];

声明了一个整型数组,数组中的每一个元素为整型数据。与C、C++不同,Java在数组的定义中并不为数组元素分配内存,因此[]中不用指出数组中元素个数,即数组长度,并且对于如上定义的一个数组是不能訪问它的不论什么元素的。我们必须为它分配内存空间,这时要用到运算符new,其格式例如以下:

arrayName=new type[arraySize];

当中,arraySize指明数组的长度。如:

intArray=new int[3];

为一个整型数组分配3个int型整数所占领的内存空间。

 

通常,这两部分能够合在一起,格式例如以下:

type arrayName=new type[arraySize];

比如:

int intArray=new int[3];

 

1.2 一维数组元素的引用

定义了一个数组,并用运算符new为它分配了内存空间后,就能够引用数组中的每个元素了。数组元素的引用方式为:

 

arrayName[index]

当中:index为数组下标,它能够为整型常数或表达式。如a[3],b[i](i为整型),c[6*I]等。下标 从0開始,一直到数组的长度减1。对于上面样例中的in-tArray数来说,它有3个元素,分别为:

intArray[0],intArray[1],intArray[2]。注意:没有intArray[3]。

 

另外,与C、C++中不同,Java对数组元素要进行越界检查以保证安全性。同一时候,对于每一个数组都有一个属性length指明它的长度,比如:intArray.length指明数组intArray的长度。

 

 

 

执行结果例如以下:

C:/>java ArrayTest

a[4]=4
a[3]=3
a[2]=2
a[1]=1
a[0]=0

该程序对数组中的每一个元素赋值,然后按逆序输出。

 

1.3 一维数组的初始化

对数组元素能够依照上述的样例进行赋值。也能够在定义数组的同一时候进行初始化。

比如:

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

用逗号(,)分隔数组的各个元素,系统自己主动为数组分配一定空间。

 

与C中不同,这时Java不要求数组为静态(static),事实上这里的变量相似C中的指针,所以将其作为返回值给其他函数使用,仍然是有效的,在C中将局部变量返回给调用函数继续使用是刚開始学习的人非常easy犯的错误。

 

 

2. 多维数组

与C、C++一样,Java中多维数组被看作数组的数组。比如二维数组为一个特殊的一维数组,其每一个元素又是一个一维数组。以下我们主要以二维数为例来进行说明,高维的情况是相似的。

 

2.1 二维数组的定义

二维数组的定义方式为:

type arrayName[][];

 

比如:

int intArray[][];

 

与一维数组一样,这时对数组元素也没有分配内存空间,同要使用运算符new来分配内存,然后才干够訪问每一个元素。

对高维数组来说,分配内存空间有以下几种方法:

 

1. 直接为每一维分配空间,如:

int a[][]=new int[2][3];

 

2. 从最高维開始,分别为每一维分配空间,如:

int a[][]=new int[2][];
a[0]=new int[3];
a[1]=new int[3];

完毕1中同样的功能。这一点与C、C++是不同的,在C、C++中必须一次指明每一维的长度。

 

2.2 二维数组元素的引用

对二维数组中每一个元素,引用方式为:arrayName[index1][index2] 当中index1、index2为下标,可为整型常数或表达式,如a[2][3]等,相同,每一维的下标都从0開始。

 

2.3 二维数组的初始化

有两种方式:

1. 直接对每一个元素进行赋值。

2. 在定义数组的同一时候进行初始化。

 

如:int a[][]={{2,3},{1,5},{3,4}};

定义了一个3×2的数组,并对每一个元素赋值。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/118074.html原文链接:https://javaforall.net

(0)
上一篇 2021年12月14日 上午7:00
下一篇 2021年12月14日 上午8:00


相关推荐

  • MySQL基础篇(DDL,DML,DQL,DCL详细讲解)

    一、常用开发工具1.NavicateNavicat是一套快速、可靠并价格相宜的数据库管理工具,专为简化数据库的管理及降低系统管理成本而设。它的设计符合数据库管理员、开发人员及中小企业的需要。Navicat是以直觉化的图形用户界面而建的,让你可以以安全并且简单的方式创建、组织、访问并共用信息。http://www.navicat.com.cn/破解方式:https://www.jb51.net/database/710931.html再手动激活[外链图片转存失败,源站可能有防盗链.

    2022年4月7日
    136
  • 【最新版本】OpenClaw(小龙虾) 完整安装指南!含Skills使用教程!

    【最新版本】OpenClaw(小龙虾) 完整安装指南!含Skills使用教程!

    2026年3月13日
    3
  • openclaw完整部署sop(含配置deepseek)

    openclaw完整部署sop(含配置deepseek)

    2026年3月13日
    5
  • 09R语言实现决策树分析

    09R语言实现决策树分析决策树是附加概率结果的一个树状的决策图 是直观的运用统计概率分析的图法 机器学习中决策树是一个预测模型 它表示对象属性和对象值之间的一种映射 树中的每一个节点表示对象属性的判断条件 其分支表示符合节点条件的对象 树的叶子节点表示对象所属的预测结果 nbsp nbsp 这一节学习使用包 party 里面的函数 ctree 为数据集 iris 建立一个决策树 属性 Sepal Length 萼片长度 Sepa

    2026年3月17日
    2
  • StarUML使用教程一览

    StarUML使用教程一览需求工程课里面老师让我们使用一个软件进行图形绘制 StarUML 简称 SU 是一种创建 UML 类图 生成类图和其他类型的统一建模语言 UML 图表的工具 StarUML 是一个开源项目之一发展快 灵活 可扩展性强 zj StarUML 官方下载地址 http staruml io download 安装教程 安装步骤很简单 省略 注意 付费软件 如需激活成功教程网上很多教程 不激活成功教程不影响使用安装之后的主界面简介如图所示 2 创建工程在启动 starUML 时 系统会默认帮我们创建一个工程如果这个

    2026年3月17日
    2
  • PyTorch中的转置卷积详解——全网最细

    PyTorch中的转置卷积详解——全网最细前言转置卷积,学名transposedconvolution,在tf和torch里都叫这个。有时在论文里可以看到别人叫它deconvolution(反卷积),但这个名词不合适。因为转置卷积并非directconvolution的逆运算(reverse),并不能还原出原张量。只是从形状上看,其结果的形状等同于逆运算。写这篇文章还是因为网上介绍转置卷积的博客,都讲不清楚,我看了半天还是云里雾里。只能自己手动来一篇了。一、基本运算——错位扫描定义本文中,我们将平时用到的普通卷积,称为dir

    2022年6月21日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号