Java数组补充v2

一、数组基本概念

1. 什么是数组

数组是Java中用来存储同类型数据固定大小连续内存空间的数据结构。

2. 数组特点

固定长度:一旦创建,长度不可改变

相同类型:所有元素必须是同一数据类型

索引访问:通过下标(从0开始)访问元素

内存连续:元素在内存中是连续存储的

二、数组声明与初始化

1. 数组声明

// 方式1:数据类型[] 数组名;
int[] arr1;// 方式2:数据类型 数组名[];
int arr2[];

推荐使用第一种方式,更符合Java规范

2. 数组初始化

(1) 静态初始化

java

  • int arrB[] = {1,2,3,4,5}

    • 这是 静态初始化的简化形式,只能在 声明数组变量时 直接使用。

    • 编译器会自动推导数组类型和长度。

    • 示例:

      java

      int arrB[] = {1, 2, 3, 4, 5}; // 正确
  • arrA = new int[]{1,2,3,4}

    • 这是 静态初始化的完整形式,可以在 声明时或后续赋值时 使用。

    • 需要显式指定数组类型 new int[],但长度由元素个数决定。

    • 示例:

      java

      int[] arrA;
      arrA = new int[]{1, 2, 3, 4}; // 正确(先声明后赋值)

使用场景不同

场景int[] arr = {1,2,3}arr = new int[]{1,2,3}
声明时直接初始化✅ 可用✅ 可用
先声明后赋值❌ 不可用✅ 可用
方法返回值❌ 不可用✅ 可用
匿名数组传参❌ 不可用✅ 可用

示例对比:

java

// 1. 声明时初始化(两种方式均可)
int[] arr1 = {1, 2, 3};          // 简化形式
int[] arr2 = new int[]{1, 2, 3}; // 完整形式// 2. 先声明后赋值(只能用完整形式)
int[] arr3;
arr3 = new int[]{1, 2, 3}; // 正确
// arr3 = {1, 2, 3};       // 错误!简化形式不能用于后续赋值// 3. 作为方法返回值(只能用完整形式)
public int[] getArray() {return new int[]{1, 2, 3}; // 正确// return {1, 2, 3};       // 错误!
}// 4. 匿名数组传参(只能用完整形式)
someMethod(new int[]{1, 2, 3}); // 正确
// someMethod({1, 2, 3});       // 错误!

3. 底层实现相同

  • 两种方式最终生成的字节码完全一致,性能无差别。

  • 内存分配方式相同:都在堆内存中创建连续存储的数组对象。


4. 风格建议

  1. 推荐使用 int[] arr 声明风格(而非 int arr[]),更符合 Java 规范。

  2. 如果只是 声明时初始化,优先使用简化形式 {1,2,3},代码更简洁。

  3. 如果需要 重新赋值或匿名使用,必须用完整形式 new int[]{1,2,3}

特性{1,2,3}new int[]{1,2,3}
语法名称简化静态初始化完整静态初始化
是否依赖声明语句必须与声明写在一起可独立使用
灵活性
推荐使用场景声明时直接初始化重新赋值、方法返回、匿名传参

(2) 动态初始化

java

// 指定长度但不指定元素值
int[] arr = new int[5]; // 默认值为0
String[] strs = new String[3]; // 默认值为null

赋值即逐个元素 循环 arraycopy scanner输入赋值都可以

三、数组基本操作

1. 访问数组元素

int[] arr = {10, 20, 30, 40, 50};// 获取元素
int num = arr[2]; // 获取第3个元素(30)// 修改元素
arr[3] = 100; // 将第4个元素改为100

2. 获取数组长度

int length = arr.length; // 注意不是length()

3. 遍历数组 

这里补充循环一定要放在方法中,不能直接在类体内

(1) 普通for循环
for(int i = 0; i < arr.length; i++) {System.out.println(arr[i]);
}
(2) 增强for循环
for(int num : arr) {System.out.println(num);
}

小练习:

//for each 增强for循环
//只是改变了item,没有改变数组也不可以改变,只能做到使用里面的数
//int a=arrB[0]; a=12;
arrB=new int[]{1,2,3,4};
for(int item:arrB){item=(int)(Math.random()*100);
}
System.out.println(Arrays.toString(arrB));//数组随机赋值,然后找出数组最大值
arrB=new int[7];
for(int i=0;i<arrB.length;i++){arrB[i]=(int)(Math.random()*100);
}
System.out.println(Arrays.toString(arrB));
int max=arrB[0];
for(int item:arrB){if(item>max){max=item;}
}
System.out.println("数组最大值是:"+max);// 数组求和
arrB=new int[7];
for(int i=0;i<arrB.length;i++){arrB[i]=(int)(Math.random()*100);
}
System.out.println(Arrays.toString(arrB));
int sum=0;
for(int item:arrB){sum+=item;
}
System.out.println(sum);//有10个裁判评分,满分为10分,使用随机数模拟,存入数组中
//从中去掉最大分数和最小分数,剩下分数的平均数就是选手得分
//打印出选手得分
//Math.random();//[0,1) *10 0-0.9.9999.. (int)一刀切只能取到9 应该*11
arrB=new int[10];
for(int i=0;i<arrB.length;i++){arrB[i]=(int)(Math.random()*11);
}
System.out.println(Arrays.toString(arrB));
max=arrB[0];
int min=arrB[0];
sum=0;
for(int item:arrB){if(item>max){max=item;}if(item<min){min=item;}sum+=item;
}int score=(sum-max-min)/8;
System.out.println(score);
(3) 使用Arrays.toString()
System.out.println(Arrays.toString(arr));

四、多维数组

1. 二维数组声明与初始化

// 静态初始化
int[][] arr1 = {{1, 2}, {3, 4}, {5, 6}};// 动态初始化
int[][] arr2 = new int[3][2]; // 3行2列

2. 二维数组遍历

for(int i = 0; i < arr.length; i++) {for(int j = 0; j < arr[i].length; j++) {System.out.print(arr[i][j] + " ");}System.out.println();
}

五、数组常用工具类Arrays

1. 排序

int[] arr = {3, 1, 4, 2, 5};
Arrays.sort(arr); // 升序排序

补充:

1.1 冒泡排序

2. 二分查找

int index = Arrays.binarySearch(arr, 4); // 必须是先排序好的才能用二分

3. 数组比较

boolean isEqual = Arrays.equals(arr1, arr2);

4. 数组填充

Arrays.fill(arr, 0); // 全部填充为0

5. 数组复制

int[] newArr = Arrays.copyOf(arr, arr.length);

6.数组扩容

拷贝数组arraycopy   五个参数
源数组  源数组的起始位置(开始复制的位置)   目标数组   目标数组的起始位置(从哪个位置开始粘贴)   拷贝的长度

//数组扩容 声明一个更大的数组代替旧的数组
int[] arrA=new int[10];
arrA[0]=99;arrA[9]=999;
int[] arrTemp=new int[arrA.length<<1];
System.arraycopy(arrA,0,arrTemp,0,arrA.length);
//原数组 原数组起始位置(从哪个位置开始粘贴) 目标数组 目标数组起始位置 拷贝的长度
arrA=arrTemp;
System.out.println(Arrays.toString(arrA));

六、数组常见问题

1. 数组越界异常

java

int[] arr = new int[3];
System.out.println(arr[3]); // ArrayIndexOutOfBoundsException

2. 空指针异常

java

int[] arr = null;
System.out.println(arr[0]); // NullPointerException

3. 数组长度不可变

java

int[] arr = new int[5];
// arr.length = 10; // 错误!数组长度不可变

七、数组与内存

1. 内存分配

  • 数组变量存储在栈内存

  • 数组元素存储在堆内存

2. 内存示意图

text

栈内存        堆内存
arr   ---->  [0][0][0][0][0]

八、数组应用场景

  1. 存储大量同类型数据

  2. 实现数据结构(如栈、队列)

  3. 矩阵运算

  4. 排序和搜索算法实现

九、数组与集合的区别

特性数组集合(ArrayList等)
长度固定动态可变
类型单一可泛型指定
性能略低
功能基础丰富的方法

十、Java 8+ 数组新特性

1. 并行排序

Arrays.parallelSort(arr);

2. Stream操作

Arrays.stream(arr).filter(n -> n > 2).forEach(System.out::println);

3. 集合转数组

List<String> list = Arrays.asList("A", "B", "C");
String[] arr = list.toArray(new String[0]);

十一、补:无限循环与死循环的区别:

//死循环 无限循环
//while(true){} 没有结束条件 死循环
i=-1;
for(;i<0;i--){}//有结束条件,逻辑上条件永远达不到,无限循环

1. 无限循环(Infinite Loop)

定义:
  • 有意创建的设计上需要永不停止的循环结构

  • 通常有特定的业务用途,是程序逻辑的一部分

特点:

✅ 是有意设计的循环结构
✅ 通常包含循环控制机制(如 break 条件)
✅ 服务于特定业务逻辑(如服务器监听、游戏主循环)

典型应用场景:

java

// 服务器主线程循环
while(true) {Socket client = serverSocket.accept(); // 等待客户端连接new Thread(new ClientHandler(client)).start();
}// 游戏主循环
while(running) {  // running是可控的布尔变量updateGame();renderFrame();
}

2. 死循环(Dead Loop)

定义:
  • 意外产生的本应终止却无法停止的循环

  • 属于程序缺陷(bug),会导致程序卡死或资源耗尽

特点:

❌ 是无意产生的程序错误
❌ 缺少正确的终止条件
❌ 会导致程序异常或系统资源耗尽

常见错误示例:

java

// 错误1:忘记更新循环变量
int i = 0;
while(i < 10) {  // i永远不会改变System.out.println("Stuck...");
}// 错误2:错误的终止条件
for(int j=1; j!=10; j+=2) { // 当j=9时,j+2=11,永远不等于10System.out.println(j);
}

关键对比表

特征无限循环死循环
设计意图有意设计意外产生
是否可控有控制机制(可退出)无法控制
业务价值实现特定功能纯属程序缺陷
典型结构while(true) + 内部break缺少变量更新/错误条件
是否应避免按需使用必须修复

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

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

相关文章

【PTA数据结构 | C语言版】前缀树的3个操作

本专栏持续输出数据结构题目集&#xff0c;欢迎订阅。 文章目录题目代码题目 请编写程序&#xff0c;利用前缀树查找给定字符串是否在某给定字符串集合 S 中。 输入格式&#xff1a; 输入首先给出一个正整数 n&#xff08;≤1000&#xff09;&#xff0c;随后 n 行&#xff0…

JAVA面试宝典 -《缓存架构:穿透 / 雪崩 / 击穿解决方案》

&#x1f4a5;《缓存架构&#xff1a;穿透 / 雪崩 / 击穿解决方案》 文章目录&#x1f4a5;《缓存架构&#xff1a;穿透 / 雪崩 / 击穿解决方案》&#x1f9ed; 一、开篇导语&#xff1a;为什么缓存是高并发系统的命脉&#xff1f;✅1.1 缓存的核心价值缓存带来的收益​​&…

FPGA创意项目网页或博客推荐

1. 综合项目平台(开源+教程) ① Hackster.io - FPGA专区 🔗 https://www.hackster.io/fpga 特点: 大量基于FPGA的创意项目(如Zynq游戏机、视觉处理、机器人控制)。 提供完整教程(Vivado工程文件+代码)。 推荐项目: FPGA-Based Oscilloscope(低成本示波器) V…

Go 程序无法使用 /etc/resolv.conf 的 DNS 配置排查记录

在最近的一次部署中&#xff0c;我遇到一个奇怪的问题&#xff1a;Go 程序在运行时不使用 /etc/resolv.conf 中的 DNS 设置&#xff0c;导致服务无法正常访问域名。这篇文章记录下完整的排查过程和最终的解决方案。1. 问题现象我有一个部署在 KVM 虚拟机内的 Go 应用&#xff0…

微服务相关问题(2)

1、Spring Cloud相关常用组件注册中心&#xff08;nacos、Eureka等&#xff09;、负载均衡&#xff08;Ribbon、LoadBalancer&#xff09;、远程调用&#xff08;feign&#xff09;、服务熔断&#xff08;Sentinel、Hystrix&#xff09;、网关&#xff08;Gateway&#xff09;2…

安全初级2

一、作业要求 1、xss-labs 1~8关 2、python实现自动化sql布尔育注代码优化(二分查找) 二、xss-labs 1~8关 1、准备 打开小皮面板&#xff0c;启动MySQL和apacher 下载 xss-labs&#xff0c;并解压后放到 phpstudy_pro 的 WWW 目录下&#xff0c;重命名为 xss-labs 访问链…

基础算法题

基础算法题 链表 1.1反转链表 描述&#xff1a; 描述 给定一个单链表的头结点pHead(该头节点是有值的&#xff0c;比如在下图&#xff0c;它的val是1)&#xff0c;长度为n&#xff0c;反转该链表后&#xff0c;返回新链表的表头。 数据范围&#xff1a; 0≤&#xfffd;≤…

Android 15 源码修改:为第三方应用提供截屏接口

概述 在 Android 系统开发中,有时需要为第三方应用提供系统级的截屏功能。本文将详细介绍如何通过修改 Android 15 源码中的 PhoneWindowManager 类,实现一个自定义广播接口来触发系统截屏功能。 修改方案 核心思路 通过在系统服务 PhoneWindowManager 中注册自定义广播监…

20250717 Ubuntu 挂载远程 Windows 服务器上的硬盘

由 DeepSeek 生成&#xff0c;方法已经验证可行。 通过网络挂载Windows共享硬盘&#xff08;SMB/CIFS&#xff09; 确保网络共享已启用&#xff1a; 在Windows电脑上&#xff0c;右键点击目标硬盘或文件夹 → 属性 → 共享 → 启用共享并设置权限&#xff08;至少赋予读取权限&…

深度学习图像增强方法(二)

三、直方图均衡化 1. 普通直方图均衡化 直方图均衡化的原理是将图像的灰度直方图展平,使得每个灰度级都有更多的像素分布,从而增强图像的对比度。具体步骤如下: 计算灰度直方图:统计图像中每个灰度级的像素数量。 计算累积分布函数(CDF):计算每个灰度级的累积概率。 映…

QT——信号与槽/自定义信号与槽

1 信号与槽基本介绍 提出疑问&#xff0c;界面上已经有按键了&#xff0c;怎么操作才能让用户按下按键后有操作上的反应呢&#xff1f; 在 Qt 中&#xff0c;信号和槽机制是一种非常强大的事件通信机制。这是一个重要的概念&#xff0c;特别是对于初学者来说&#xff0c;理解它…

Spring原理揭秘--Spring的AOP

在这之前我们已经介绍了AOP的基本功能和概念&#xff0c;那么当AOP集成到spring则会发生改变。Spring AOP 中的Joinpoint&#xff1a;之前提高了很多Joinpoint的类型&#xff0c;但是在spring中则只会有方法级别的Joinpoint&#xff0c;像构造方法&#xff0c;字段的调用都没适…

C++学习笔记五

C继承//基类 class Animal{};//派生类 class Dog : public Animal{};#include<iostearm> using namespace std;//基类 class Shape{public:void setwidth(int w){width w;}void setheight(int h){height h;}protected:int width;int height;}//派生类 class Rectangle …

AndroidStudio环境搭建

一、AndroidStudio下载 正常百度出来的站会自动翻译成中文&#xff0c;导致历史版本的界面总是显示不出可下载的地方&#xff0c;点击成切回英文&#xff0c;就能看出了。 历史版本&#xff1a;https://developer.android.google.cn/studio/archive

Java大厂面试实录:从Spring Boot到AI大模型的深度技术拷问

场景&#xff1a;互联网大厂Java后端面试 面试官&#xff08;严肃&#xff09;&#xff1a;小曾&#xff0c;请坐。今天主要考察Java后端技术栈&#xff0c;包括微服务、大数据、AI等。我们先从简单问题开始。 小曾&#xff08;搓手&#xff09;&#xff1a;好嘞&#xff01;面…

深入解析Hadoop中的HDFS架构设计

HDFS概述与核心设计原则作为Hadoop生态系统的基石&#xff0c;HDFS&#xff08;Hadoop Distributed File System&#xff09;是一种专为大规模数据处理而设计的分布式文件系统。它的核心设计理念源于对互联网时代数据特征的深刻洞察——数据规模呈指数级增长&#xff0c;而硬件…

ota之.加密算法,mcu加密方式

一、ota之.加密算法&#xff0c;mcu加密方式 前面一篇文章&#xff0c;讲了soc的加密方式&#xff0c;但是soc资源充足&#xff0c;mcu没有&#xff0c;所以不会用openss生成公私钥 切计算哈希用rsa256位。 ECC&#xff08;椭圆曲线加密&#xff09; 是一种非对称加密算法&…

LangChain面试内容整理-知识点23:实战案例:检索增强生成(RAG)系统

检索增强生成(Retrieval-Augmented Generation, RAG)是一种将LLM与外部知识库结合的方法,通过实时检索相关信息来辅助生成答案。这极大缓解了LLM“封闭知识”过期或不足的问题。LangChain非常适合构建RAG系统,因为它提供了文档加载、向量存储、检索接口、LLM组合的一站式方…

探索阿里云ESA:开启边缘安全加速新时代

阿里云 ESA 是什么&#xff1f;阿里云 ESA&#xff0c;全称边缘安全加速&#xff08;Edge Security Acceleration&#xff09; &#xff0c;其前身为全站加速 DCDN&#xff08;Dynamic Content Delivery Network&#xff09;。在 2024 年 9 月 30 日&#xff0c;阿里云完成了这…

醋酸铈:赋能科技创新的稀土之力

一、什么是醋酸铈醋酸铈是铈元素与醋酸根离子形成的化合物。铈作为稀土元素中的重要一员&#xff0c;广泛应用于材料科学、催化剂、电子产品等领域。醋酸铈以无色结晶或浅黄色结晶的形式存在&#xff0c;是铈的有机盐之一。它不仅具有稳定的化学性质&#xff0c;而且在某些特定…