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

java程序员必备的基础知识之数组的定义和使用

wptr33 2025-03-19 03:11 20 浏览

如果希望保存一组有相同类型的数据,可以使用数组。

数组的定义和内存分配

Java 中定义数组的语法有两种:

type arrayName[];

type[] arrayName;

type 为Java中的任意数据类型,包括基本类型和组合类型,arrayName为数组名,必须是一个合法的标识符,[ ] 指明该变量是一个数组类型变量。例如:

1. int demoArray[];

2. int[] demoArray;

这两种形式没有区别,使用效果完全一样,读者可根据自己的编程习惯选择。

与C、C++不同,Java在定义数组时并不为数组元素分配内存,因此[ ]中无需指定数组元素的个数,即数组长度。而且对于如上定义的一个数组是不能访问它的任何元素的,我们必须要为它分配内存空间,这时要用到运算符new,其格式如下:

arrayName=new type[arraySize];

其中,arraySize 为数组的长度,type 为数组的类型。如:

复制纯文本新窗口

1. demoArray=new int[3];

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

通常,你可以在定义的同时分配空间,语法为:

type arrayName[] = new type[arraySize];

例如:

1. int demoArray[] = new int[3];

数组的初始化

你可以在声明数组的同时进行初始化(静态初始化),也可以在声明以后进行初始化(动态初始化)。例如:

1. // 静态初始化

2. // 静态初始化的同时就为数组元素分配空间并赋值

3. int intArray[] = {1,2,3,4};

4. String stringArray[] = {"微学苑", "http://www.weixueyuan.net", "一切编程语言都是纸老虎"};

5.

6. // 动态初始化

7. float floatArray[] = new float[3];

8. floatArray[0] = 1.0f;

9. floatArray[1] = 132.63f;

10. floatArray[2] = 100F;

数组引用

可以通过下标来引用数组:

arrayName[index];

与C、C++不同,Java对数组元素要进行越界检查以保证安全性。

每个数组都有一个length属性来指明它的长度,例如 intArray.length 指明数组 intArray 的长度。

【示例】写一段代码,要求输入任意5个整数,输出它们的和。

1. import java.util.*;

2. public class Demo {

3. public static void main(String[] args){

4. int intArray[] = new int[5];

5. long total = 0;

6. int len = intArray.length;

7.

8. // 给数组元素赋值

9. System.out.print("请输入" + len + "个整数,以空格为分隔:");

10. Scanner sc = new Scanner(System.in);

11. for(int i=0; i<len; i++){

12. intArray = sc.nextInt();

13. }

14.

15. // 计算数组元素的和

16. for(int i=0; i<len; i++){

17. total += intArray;

18. }

19.

20. System.out.println("所有数组元素的和为:" + total);

21. }

22. }

运行结果:

请输入5个整数,以空格为分隔:10 20 15 25 50

所有数组元素的和为:120

数组的遍历

实际开发中,经常需要遍历数组以获取数组中的每一个元素。最容易想到的方法是for循环,例如:

1. int arrayDemo[] = {1, 2, 4, 7, 9, 192, 100};

2. for(int i=0,len=arrayDemo.length; i<len; i++){

3. System.out.println(arrayDemo + ", ");

4. }

输出结果:

1, 2, 4, 7, 9, 192, 100,

不过,Java提供了”增强版“的for循环,专门用来遍历数组,语法为:

1. for( arrayType varName: arrayName ){

2. // Some Code

3. }

arrayType 为数组类型(也是数组元素的类型);varName 是用来保存当前元素的变量,每次循环它的值都会改变;arrayName 为数组名称。

每循环一次,就会获取数组中下一个元素的值,保存到 varName 变量,直到数组结束。即,第一次循环 varName 的值为第0个元素,第二次循环为第1个元素......例如:

1. int arrayDemo[] = {1, 2, 4, 7, 9, 192, 100};

2. for(int x: arrayDemo){

3. System.out.println(x + ", ");

4. }

输出结果与上面相同。

这种增强版的for循环也被称为”foreach循环“,它是普通for循环语句的特殊简化版。所有的foreach循环都可以被改写成for循环。

但是,如果你希望使用数组的索引,那么增强版的 for 循环无法做到。

二维数组

二维数组的声明、初始化和引用与一维数组相似:

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

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

3. a[0][0] = 12;

4. a[0][1] = 34;

5. // ......

6. a[1][2] = 93;

java语言中,由于把二维数组看作是数组的数组,数组空间不是连续分配的,所以不要求二维数组每一维的大小相同。例如:

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

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

3. a[0] = new int[3];

4. a[1] = new int[5];

【示例】通过二维数组计算两个矩阵的乘积。

1. public class Demo {

2. public static void main(String[] args){

3. // 第一个矩阵(动态初始化一个二维数组)

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

5. // 第二个矩阵(静态初始化一个二维数组)

6. int b[][] = { {1,5,2,8}, {5,9,10,-3}, {2,7,-5,-18} };

7. // 结果矩阵

8. int c[][] = new int[2][4];

9.

10. // 初始化第一个矩阵

11. for(int i=0; i<2; i++)

12. for(int j=0; j<3 ;j++)

13. a[j] = (i+1) * (j+2);

14.

15. // 计算矩阵乘积

16. for (int i=0; i<2; i++){

17. for (int j=0; j<4; j++){

18. c[j]=0;

19. for(int k=0; k<3; k++)

20. c[j] += a[k] * b[k][j];

21. }

22. }

23.

24. // 输出结算结果

25. for(int i=0; i<2; i++){

26. for (int j=0; j<4; j++)

27. System.out.printf("%-5d", c[j]);

28. System.out.println();

29. }

30. }

31. }

运行结果:

25 65 14 -65

50 130 28 -130

几点说明:

· 上面讲的是静态数组。静态数组一旦被声明,它的容量就固定了,不容改变。所以在声明数组时,一定要考虑数组的最大容量,防止容量不够的现象。

· 如果想在运行程序时改变容量,就需要用到数组列表(ArrayList,也称动态数组)或向量(Vector)。

· 正是由于静态数组容量固定的缺点,实际开发中使用频率不高,被 ArrayList 或 Vector 代替,因为实际开发中经常需要向数组中添加或删除元素,而它的容量不好预估。

相关推荐

oracle数据导入导出_oracle数据导入导出工具

关于oracle的数据导入导出,这个功能的使用场景,一般是换服务环境,把原先的oracle数据导入到另外一台oracle数据库,或者导出备份使用。只不过oracle的导入导出命令不好记忆,稍稍有点复杂...

继续学习Python中的while true/break语句

上次讲到if语句的用法,大家在微信公众号问了小编很多问题,那么小编在这几种解决一下,1.else和elif是子模块,不能单独使用2.一个if语句中可以包括很多个elif语句,但结尾只能有一个else解...

python continue和break的区别_python中break语句和continue语句的区别

python中循环语句经常会使用continue和break,那么这2者的区别是?continue是跳出本次循环,进行下一次循环;break是跳出整个循环;例如:...

简单学Python——关键字6——break和continue

Python退出循环,有break语句和continue语句两种实现方式。break语句和continue语句的区别:break语句作用是终止循环。continue语句作用是跳出本轮循环,继续下一次循...

2-1,0基础学Python之 break退出循环、 continue继续循环 多重循

用for循环或者while循环时,如果要在循环体内直接退出循环,可以使用break语句。比如计算1至100的整数和,我们用while来实现:sum=0x=1whileTrue...

Python 中 break 和 continue 傻傻分不清

大家好啊,我是大田。今天分享一下break和continue在代码中的执行效果是什么,进一步区分出二者的区别。一、continue例1:当小明3岁时不打印年龄,其余年龄正常循环打印。可以看...

python中的流程控制语句:continue、break 和 return使用方法

Python中,continue、break和return是控制流程的关键语句,用于在循环或函数中提前退出或跳过某些操作。它们的用途和区别如下:1.continue(跳过当前循环的剩余部分,进...

L017:continue和break - 教程文案

continue和break在Python中,continue和break是用于控制循环(如for和while)执行流程的关键字,它们的作用如下:1.continue:跳过当前迭代,...

作为前端开发者,你都经历过怎样的面试?

已经裸辞1个月了,最近开始投简历找工作,遇到各种各样的面试,今天分享一下。其实在职的时候也做过面试官,面试官时,感觉自己问的问题很难区分候选人的能力,最好的办法就是看看候选人的github上的代码仓库...

面试被问 const 是否不可变?这样回答才显功底

作为前端开发者,我在学习ES6特性时,总被const的"善变"搞得一头雾水——为什么用const声明的数组还能push元素?为什么基本类型赋值就会报错?直到翻遍MDN文档、对着内存图反...

2023金九银十必看前端面试题!2w字精品!

导文2023金九银十必看前端面试题!金九银十黄金期来了想要跳槽的小伙伴快来看啊CSS1.请解释CSS的盒模型是什么,并描述其组成部分。答案:CSS的盒模型是用于布局和定位元素的概念。它由内容区域...

前端面试总结_前端面试题整理

记得当时大二的时候,看到实验室的学长学姐忙于各种春招,有些收获了大厂offer,有些还在苦苦面试,其实那时候的心里还蛮忐忑的,不知道自己大三的时候会是什么样的一个水平,所以从19年的寒假放完,大二下学...

由浅入深,66条JavaScript面试知识点(七)

作者:JakeZhang转发链接:https://juejin.im/post/5ef8377f6fb9a07e693a6061目录由浅入深,66条JavaScript面试知识点(一)由浅入深,66...

2024前端面试真题之—VUE篇_前端面试题vue2020及答案

添加图片注释,不超过140字(可选)1.vue的生命周期有哪些及每个生命周期做了什么?beforeCreate是newVue()之后触发的第一个钩子,在当前阶段data、methods、com...

今年最常见的前端面试题,你会做几道?

在面试或招聘前端开发人员时,期望、现实和需求之间总是存在着巨大差距。面试其实是一个交流想法的地方,挑战人们的思考方式,并客观地分析给定的问题。可以通过面试了解人们如何做出决策,了解一个人对技术和解决问...