java05 数组

一 概念介绍

指的是一种容器,可以同来存储同种数据类型的多个值。

但是数组容器在存储数据的时候,需要结合隐式转换考虑。

比如:

定义了一个int类型的数组。那么boolean。double类型的数据是不能存到这个数组中的,

但是byte类型,short类型,int类型的数据是可以存到这个数组里面的。

建议:

容器的类,和存储的数据类型保持一致。

举例:

整数1 2 3 4 56 就可以使用int类型的数组来存储。

小数1.1 1.2 1.3 1.4 就可以使用double类型的数组来存储。

字符串"aaa" "bbb" "ccc" 就可以使用String类型的数组来存储。

二 定义

1.格式一:

数据类型 [] 数组名

比如:int [] array

格式二:

数据类型 数组名 []

比如: int array []

数据类型:限定了数组以后能存什么类型的数据。

方括号:表示现在定义的是一个数组。

数组名:就是一个名字而已,方便以后使用。

三 静态初始化

就是在内存中,为数组容器开辟空间,并将数据存入容器中的过程

完整格式:

数据类型[] 数组名 = new 数据类型[]{元素1,元素2,元素3,元素4...};

比如:int[] arr = new int[]{11,22,33};double[] arr = new double[]{1.1,1.2,1.3};

数据类型:限定了数组以后能存什么类型的数据。

方括号:表示现在定义的是一个数组。

数组名:其实就是名字而已,方便以后使用,在起名字的时候遵循小驼峰命名法。

arr namesArr

new:就是给数组在内存中开辟了一个空间。

数据类型:限定了数组以后能存什么类型的数据。

前面和后面的数据类型一定要保持一致。

int[] arr = new double[]{11,22,33};//错误写法

方括号:表示现在定义的是一个数组。

大括号:表示数组里面的元素。元素也就是存入到数组中的数据。

多个元素之间,一定要用逗号隔开。

注意点:

  • 等号前后的数据类型必须保持一致。

  • 数组一旦创建之后,长度不能发生变化。

简化格式:

数据类型[] 数组名 = {元素1,元素2,元素3,元素4...};

比如:int[] array = {1,2,3,4,5};double[] array = {1.1,1.2,1.3};

  练习

定义数组存储5个学生的年龄。

 

定义数组存储3个学生的姓名。

 

定义数组存储4个学生的身高。

 

四 地址值

打印数组的时候,实际出现的是数组的地址值。

数组的地址值:就表示数组在内存中的位置。

以[I@6d03e736为例:

[ :表示现在打印的是一个数组。

I:表示现在打印的数组是int类型的。

@:仅仅是一个间隔符号而已。

6d03e736:就是数组在内存中真正的地址值。(十六进制的)

但是,我们习惯性会把[I@6d03e736这个整体称之为数组的地址值。

五 元素访问

格式:

数组名[索引];

索引的特点:

  • 索引一定是从0开始的。

  • 连续不间断。

  • 逐个+1增长。

作用:

  • 获取数组中对应索引上的值

  • 修改数组中对应索引上的值

    一旦修改之后,原来的值就会被覆盖了。

示例

package com.wy.arraydemo;public class ArrayDemo2 {public static void main(String[] args) {int[] arr={1,2,3,4,5};int number=arr[0];System.out.println(number);System.out.println(arr[1]);}
}

六  数组的遍历

就是把数组里面所有的内容一个一个全部取出来。

数组的长度:数组名.length;

package com.wy.arraydemo;public class ArrayDemo3 {public static void main(String[] args) {int[] arr={1,2,3,4,5};for(int i=0;i<arr.length;i++){System.out.println(arr[i]);}}
}

练习

定义一个数组,存储1,2,3,4,5遍历数组得到每一个元素,求数组里面所有的数据和

 

package com.wy.test;public class Arraytest1 {public static void main(String[] args) {int arr[] ={1,2,3,4,5};int sum=0;for (int i = 0; i < arr.length; i++) {sum=sum+arr[i];}System.out.println(sum);}
}

定义一个数组,存储1,2,3,4,5,6,7,8,9,10

遍历数组得到每一个元素,统计数组里面一共有多少个能被3整除的数字

 

package com.wy.test;public class Arraytest2 {public static void main(String[] args) {int[] arr={1,2,3,4,5,6,7,8,9,10};int sum=0;for (int i = 0; i < arr.length; i++) {if(arr[i]%3==0){sum++;}}System.out.println(sum);}
}

定义一个数组,存储1,2,3,4,5,6,7,8,9,10遍历数组得到每一个元素。

要求:
1,如果是奇数,则将当前数字扩大两倍
2,如果是偶数,则将当前数字变成二分之一

package com.wy.test;public class Arraytest3 {public static void main(String[] args) {int[] arr={1,2,3,4,5,6,7,8,9,10};for (int i = 0; i < arr.length; i++) {if(arr[i]%2==1){arr[i]=2*arr[i];}else{arr[i]=arr[i]/2;}}for (int i = 0; i < arr.length; i++) {System.out.println(arr[i]);}}
}

 

 

七 动态初始化

格式:

数据类型[] 数组名 = new 数据类型[数组的长度];

package com.wy.arraydemo;public class ArrayDemo4 {public static void main(String[] args) {String[] arr=new String[50]; //c创建arr[0]="a";  //添加arr[1]="b";System.out.println(arr[0]);  //获取System.out.println(arr[1]);System.out.println(arr[2]);}
}

数组的默认初始化值:

整数类型:0

小数类型:0.0

布尔类型:false

字符类型:'\u0000'

引用类型:null

动态与静态初始化区别

静态初始化:int[] arr = {1,2,3,4,5};

动态初始化:int[] arr = new int[3];

静态初始化:手动指定数组的元素,系统会根据元素的个数,计算出数组的长度。

动态初始化:手动指定数组长度,由系统给出默认初始化值。

八 常见问题

当访问了数组中不存在的索引,就会引发索引越界异常。

避免:

针对于任意一个数组,索引的范围:

最小索引:0

最大索引:数组的长度 - 1 数组名.length - 1

九 练习

1.需求:已知数组元素为{33,5,22,44,55}
请找出数组中最大值并打印在控制台

package com.wy.test;public class Arraytest4 {public static void main(String[] args) {int[] arr={33,5,22,44,55};int max=arr[0]; //认为0索引最大for (int i = 0; i < arr.length; i++) {if(arr[i]>max){max=arr[i];}}System.out.println(max);}
}

 

2.需求:生成10个1~100之间的随机数存入数组。

1)求出所有数据的和

2)求所有数据的平均数

3)统计有多少个数据比平均值小

 

package com.wy.test;import java.util.Random;public class Arraytest5 {public static void main(String[] args) {int[] arr=new int[10];Random r=new Random(); //把随机数放进数组for (int i = 0; i < arr.length; i++) {//每循环一次,就会生成一个新的随机数int number = r.nextInt(100)+1;arr[i]=number;}//求和int sum=0;for (int i = 0; i < arr.length; i++) {sum=sum+arr[i];}System.out.println("数组和是"+sum);//求平均数int avg=sum/arr.length;System.out.println("平均数是"+avg);//比较int count=0;for (int i = 0; i < arr.length; i++) {if(arr[i]<avg){count++;}}System.out.println("比平均数小的数有"+count+"个");//验证for (int i = 0; i < arr.length; i++) {System.out.print(arr[i]+" ");}}
}

 

3.需求:定义一个数组,存入1,2,3,4,5。按照要求交换索引对应的元素。

交换前:1,2,3,4,5

交换后:5,2,3,4,1

package com.wy.test;public class Arraytest6 {public static void main(String[] args) {int[] arr={1,2,3,4,5};for(int i=0,j=arr.length-1;i<j;i++,j--){int temp=arr[i];arr[i]=arr[j];arr[j]=temp;}for (int i = 0; i < arr.length; i++) {System.out.print(arr[i]+" ");}}}

 

4.需求:定义一个数组,存入1~5。要求打乱数组中所有数据的顺序。

package com.wy.test;import java.util.Random;public class Arraytest7 {public static void main(String[] args) {int[] arr = {1, 2, 3, 4, 5};Random r = new Random();for (int i = 0; i < arr.length; i++) {int randomindex = r.nextInt(arr.length); //生成随即索引int temp = arr[i];arr[i] = arr[randomindex];  //随机交换arr[randomindex] = temp;}for (int i = 0; i < arr.length; i++) {System.out.println(arr[i]);}}
}

 

十 数组内存图

  • 栈  ---》方法运行时使用的内存,比如main方法运行,进入方法栈中执行
  • 堆 ----》存储对象或者数组,new来创建的,都存储在堆内存
  • 方法区 ---》存储可以运行的class文件
  • 本地方法栈 ---》JVM在使用操作系统功能的时候使用
  • 寄存器 ---》给cpu使用和我们开发无关 

 

 

 

两个数组指向同一空间

 

 

 

当两个数组指向同一个小空间时,其中一个数组对小空间中的值发生了改变,那么其他数组再次访问的时候都是修改之后的结果了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/450427.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

1895_分离进程的能力

1895_分离进程的能力 全部学习汇总&#xff1a; g_unix: UNIX系统学习笔记 (gitee.com) 有些理念可能在控制类的嵌入式系统中不好实施&#xff0c;尤其是没有unix这样的系统搭载的情况下。如果是考虑在RTOS的基础上看是否有一些理念可以做尝试&#xff0c;我觉得还是可以有一定…

绝世唐门:霍挂六个十万年魂环,一穿七灭团再现,淘汰赛顺利晋级

Hello,小伙伴们&#xff0c;我是拾荒君。 国漫《斗罗大陆2绝世唐门》第32期超前爆料&#xff0c;霍雨浩开局便释放六个十万年魂环&#xff0c;以绝对的气场碾压天灵学院代表队。首次参与高级魂师大赛&#xff0c;霍雨浩便大放异彩秀出超级霍挂&#xff0c;此等操作就连当初的唐…

[Python] scikit-learn中数据集模块介绍和使用案例

sklearn.datasets模块介绍 在scikit-learn中&#xff0c;可以使用sklearn.datasets模块中的函数来构建数据集。这个模块提供了用于加载和生成数据集的函数。 API Reference — scikit-learn 1.4.0 documentation 以下是一些常用的sklearn.datasets模块中的函数 load_iris() …

数字巨轮航行大数据海洋:数据可视化引领时代潮流

在大数据时代的潮流中&#xff0c;数据可视化如同一艘畅行无阻的科技巨轮&#xff0c;引领我们穿越数字浩瀚的大海&#xff0c;使我们在信息的航程中游刃有余。下面我就从可视化从业者的角度&#xff0c;来简单说说数据可视化是如何帮助我们在大数据时代畅行无阻的。 数据可视化…

1、安全开发-Python爬虫EDUSRC目标FOFA资产Web爬虫解析库

用途&#xff1a;个人学习笔记&#xff0c;有所借鉴&#xff0c;欢迎指正 前言&#xff1a; 主要包含对requests库和Web爬虫解析库的使用&#xff0c;python爬虫自动化&#xff0c;批量信息收集 Python开发工具&#xff1a;PyCharm 2022.1 激活破解码_安装教程 (2022年8月25日…

CentOS 8 下载

https://mirrors.bfsu.edu.cn/centos/8-stream/isos/x86_64/ 下载地址&#xff1a; https://mirrors.bfsu.edu.cn/centos/8-stream/isos/x86_64/CentOS-Stream-8-x86_64-latest-dvd1.iso

【第二十二课】最短路:多源最短路floyd算法(acwing-852 spfa判断是否存在负环 / acwing-854 / c++代码)

目录 acwing-852 代码如下 一些解释 acwing-854 foyld算法思想 代码如下 一些解释 acwing-852 在spfa求最短路的算法基础上进行修改。 代码如下 #include<iostream> #include<cstring> #include<algorithm> #include<queue> using names…

适用于 Windows 7/8/10/11电脑的 12 款顶级数据恢复软件

很多时候&#xff0c;我们在 Windows 7 /8/10/11下不小心按了删除键&#xff0c;从而丢失了硬盘或 USB 驱动器中的重要文件和数据。在某些情况下&#xff0c;病毒或软件错误可能会损坏您的硬盘&#xff0c;从而影响您的文件。在这种情况下&#xff0c;您迫切需要一款适用于 Win…

坚持刷题|二叉树的前、中、后序遍历(递归迭代)

文章目录 题目思考递归实现迭代实现前序遍历后序遍历中序遍历 在前、中、后序的迭代遍历中&#xff0c;为什么都采用栈来模拟递归&#xff0c;而非队列&#xff1f; Hello&#xff0c;大家好&#xff0c;我是阿月。坚持刷题&#xff0c;老年痴呆追不上我&#xff0c;今天刷&…

030 可变参数

可变参数定义 public static void main(String[] args) {// 多参数方式传递System.out.println(max(1,3,5,3,6,1,2));// 数组方式传递System.out.println(max(new int[]{1,3,5,3,6,1,2})); }static int max(int... nums){int max Integer.MIN_VALUE;for (int num : nums) {if(…

redis布隆过滤器(Bloom)详细使用教程

文章目录 布隆过滤器1. 原理2. 结构和操作3. 特点和应用场景4. 缺点和注意事项 应用-redis插件布隆过滤器使用详细过程安装以及配置springboot项目使用redis布隆过滤器下面是布隆过滤器的一些基础命令 扩展 布隆过滤器 Bloom 过滤器是一种概率型数据结构&#xff0c;用于快速判…

echarts step line

https://ppchart.com/#/ <template><div class"c-box" ref"jsEchart"></div> </template><script> import * as $echarts from echarts // 事件处理函数 export default {props: {// 需要传递的数据data: {type: Array,defa…