Java基础之一维数组
数组概念
数组(Array),多个相同类型数据按一定顺序排列的集合,并使用一个名字命名,并通过编号的方式对这些数据统一管理
数组常见概念
可以是任意数据类型。包括基本数据类型和引用数据类型
数组长度确定下来就不能更改
创建数组对象会在内存中开辟一段连续的空数组的概述
数组名下标或者索引元素数组长度
数组有序排列的
通过下标进行管理
数组长度就是元素个数
数组本身属于引用数据类型,数组元素间,而数组名中引用的是这块连续空间的首地址
可以通过数组下标或者索引的方式调用指定位置的元素,速度很快
数组分类按照维度:一维数组、二维数组、三维数组按照元素数据类型:基本数据类型、引用数据类型
一维数组的使用
一维数组的声明和初始化
1 2 3 4 5 6 7 | //1.数组声明与初始化 int [] ids; //声明 //静态初始化 ids = new int []{ 1001 , 1002 , 1003 , 1004 }; //动态初始化 String[] names = new String[ 5 ]; //数组初始化完成长度就确定下来了 |
如何调用数组指定位置的元素
1 2 3 4 5 6 7 8 9 10 11 12 13 | //2.如何调用数组的指定位置元素:。 //数组下标从0开始的。到数组的长度-1. names[ 0 ] = "zd" ; names[ 1 ] = "wxm" ; names[ 2 ] = "ws" ; names[ 3 ] = "ds" ; names[ 4 ] = "cx" ; System.out.println(names[ 0 ]); //调用names数组里的0号下标的元素 System.out.println(names.length); //显示数组长度 测试 zd 5 |
如何遍历数组
1 2 3 4 5 6 7 8 9 10 11 | //遍历数组元素 for ( int i= 0 ; i<names.length;i++){ System.out.println(names[i]); } 测试 zd wxm ws ds cx |
数组元素默认初始化值
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 | //数组元素默认初始化值 // 数组元素是整数型,0 // 数组元素是浮点型,0.0 // 数组元素是char型、‘\u000’ // 数组元素布尔型,false // 数组元素是引用数据类型String是,默认值null;注意不是"null" int [] arr = new int [ 4 ]; for ( int i= 0 ; i<arr.length;i++){ System.out.println(arr[i]); //int型数组默认初始化值是0 } String[] cd = new String[ 6 ]; for ( int i= 0 ;i<cd.length;i++){ System.out.println(cd[i]); // String型数组元素为null } boolean [] dd= new boolean [ 5 ]; for ( int i = 0 ; i < dd.length;i++){ System.out.println(dd[i]); //默认初始化值false } double [] ee = new double [ 5 ]; for ( int i = 0 ; i < ee.length;i++){ System.out.println(ee[i]); //默认0.0 } char [] cc = new char [ 4 ]; for ( int i = 0 ; i < cc.length;i++){ System.out.println(cc[i]); //默认值为'/u000' } 测试 0 0 0 0 null null null null null null false false false false false 0.0 0.0 0.0 0.0 0.0 Process finished with exit code 0 |
数组内存的解析
JVM内存大概分为栈(stack)、堆(heap)、方法区(分为常量池,静态域);栈的结构是线性结构与堆相比比较瘦,栈存放的是局部变量;堆里存放的是new出来的结构,对象和数组
学生成绩
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 | Scanner scan = new Scanner(System.in); System.out.print( "请输入学生个数:" ); int cx = scan.nextInt(); int [] Grades = new int [cx]; for ( int i = 0 ;i <cx ;){ i++; System.out.print( "请输入学生" +i+ "成绩:" ); int sxi = scan.nextInt(); Grades[i- 1 ] = sxi; //System.out.println(Grades[i-1]); } int masx = 0 ; for ( int i= 0 ; i<Grades.length;i++){ if (masx<Grades[i]){ masx=Grades[i]; } } System.out.println( "最高成绩" +masx); for ( int i= 0 ;i<Grades.length;i++){ if (Grades[i]>= 90 ){ System.out.println(Grades[i]+ "优秀" ); } else if (Grades[i]>= 80 ){ System.out.println(Grades[i]+ "好" ); } else if (Grades[i]>= 70 ){ System.out.println(Grades[i]+ "良好" ); } else if (Grades[i]>= 60 ) { System.out.println(Grades[i]+ "勉强及格" ); } else { System.out.println(Grades[i]+ "继续努力" ); } } 测试 请输入学生个数: 6 请输入学生 1 成绩: 90 请输入学生 2 成绩: 50 请输入学生 3 成绩: 56 请输入学生 4 成绩: 87 请输入学生 5 成绩: 76 请输入学生 6 成绩: 69 最高成绩 90 90 优秀 50 继续努力 56 继续努力 87 好 76 良好 69 勉强及格 |
草都可以从石头缝隙中长出来更可况你呢
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· 葡萄城 AI 搜索升级:DeepSeek 加持,客户体验更智能
· 什么是nginx的强缓存和协商缓存
· 一文读懂知识蒸馏