0

0

如何修复 Java 中数组赋值错误导致的 null 输出问题

聖光之護

聖光之護

发布时间:2026-01-05 13:53:23

|

839人浏览过

|

来源于php中文网

原创

如何修复 Java 中数组赋值错误导致的 null 输出问题

本文详解因数组元素赋值方向错误(如将 `nama[i] = lulus1[i]` 误写为 `lulus1[i] = nama[i]` 的反向操作)导致输出全为 `null` 的典型 bug,并提供完整修正方案、逻辑梳理与健壮性优化建议。

在您提供的 Java 程序中,核心问题出在数组赋值逻辑颠倒,直接导致 lulus1、tlulus1、lulus2、tlulus2 四个结果数组始终输出 null。根本原因在于:您本意是“将合格学生姓名存入 lulus1”,但代码却错误地执行了 nama[i] = lulus1[i] —— 此时 lulus1[i] 初始值为 null,于是把 nama[i] 覆盖成了 null,不仅丢失原始姓名,还使后续 Arrays.toString() 显示 [null, null, ...]。

✅ 正确赋值逻辑(关键修复)

应严格遵循“目标数组 ← 源数据”原则:

// ✅ 正确:满足 KKM 的学生姓名存入 lulus1
if (nilai1[i] >= kkm1) {
    lulus1[k] = nama[i];  // ← 注意:使用独立索引 k 避免空位
    k++; // 记录实际存入数量
} else {
    tlulus1[j] = nama[i]; // 同理,用独立索引 j 处理不通过者
    j++;
}

但原代码还存在更深层问题:未区分有效索引与数组容量。直接使用 i 作为 lulus1[i] 下标,会导致:

Unscreen
Unscreen

AI智能视频背景移除工具

下载
  • 当某学生不满足 KKM 时,lulus1[i] 保持 null;
  • 最终 Arrays.toString(lulus1) 输出含大量 null 的稀疏数组(如 [null, "Andi", null, "Budi"]),而非紧凑结果。

? 完整修正版(含健壮性增强)

import java.util.Arrays;
import javax.swing.JOptionPane;

public class Testing {
    public static void main(String[] args) {
        int batas = Integer.parseInt(JOptionPane.showInputDialog("Batas Siswa"));
        String[] nama = new String[batas];
        int[] nilai1 = new int[batas];
        int[] nilai2 = new int[batas];
        String mapel1 = JOptionPane.showInputDialog("Masukan Mapel 1");
        String mapel2 = JOptionPane.showInputDialog("Masukan Mapel 2");
        int kkm1 = Integer.parseInt(JOptionPane.showInputDialog("Input KKM 1"));
        int kkm2 = Integer.parseInt(JOptionPane.showInputDialog("Input KKM 2"));

        // 动态收集结果(避免 null 占位)
        java.util.List<String> lulus1List = new java.util.ArrayList<>();
        java.util.List<String> tlulus1List = new java.util.ArrayList<>();
        java.util.List<String> lulus2List = new java.util.ArrayList<>();
        java.util.List<String> tlulus2List = new java.util.ArrayList<>();

        int total1 = 0, total2 = 0;

        for (int i = 0; i < batas; i++) {
            nama[i] = JOptionPane.showInputDialog("Nama Siswa ke-" + (i+1));
            nilai1[i] = Integer.parseInt(JOptionPane.showInputDialog("Input Nilai " + mapel1));
            total1 += nilai1[i];

            if (nilai1[i] >= kkm1) {
                lulus1List.add(nama[i]);
            } else {
                tlulus1List.add(nama[i]);
            }

            nilai2[i] = Integer.parseInt(JOptionPane.showInputDialog("Input Nilai " + mapel2));
            total2 += nilai2[i];

            if (nilai2[i] >= kkm2) {
                lulus2List.add(nama[i]);
            } else {
                tlulus2List.add(nama[i]);
            }
        }

        // 转为数组(紧凑无 null)
        String[] lulus1 = lulus1List.toArray(new String[0]);
        String[] tlulus1 = tlulus1List.toArray(new String[0]);
        String[] lulus2 = lulus2List.toArray(new String[0]);
        String[] tlulus2 = tlulus2List.toArray(new String[0]);

        // 统计计算(修复 min/max 循环范围)
        int max1 = Arrays.stream(nilai1).max().orElse(0);
        int min1 = Arrays.stream(nilai1).min().orElse(0);
        int max2 = Arrays.stream(nilai2).max().orElse(0);
        int min2 = Arrays.stream(nilai2).min().orElse(0);

        int Ttotal = total1 + total2;
        int rata = batas > 0 ? Ttotal / (2 * batas) : 0; // 修正平均值逻辑:每科人均分

        // 输出(清晰、无 null)
        System.out.println("=== HASIL ANALISIS ===");
        System.out.println("Nilai Rata-rata Keseluruhan: " + rata);
        System.out.println("Nilai Tertinggi " + mapel1 + ": " + max1);
        System.out.println("Nilai Terendah " + mapel1 + ": " + min1);
        System.out.println("Nilai Tertinggi " + mapel2 + ": " + max2);
        System.out.println("Nilai Terendah " + mapel2 + ": " + min2);
        System.out.println("Siswa Lulus " + mapel1 + ": " + Arrays.toString(lulus1));
        System.out.println("Siswa Tidak Lulus " + mapel1 + ": " + Arrays.toString(tlulus1));
        System.out.println("Siswa Lulus " + mapel2 + ": " + Arrays.toString(lulus2));
        System.out.println("Siswa Tidak Lulus " + mapel2 + ": " + Arrays.toString(tlulus2));
    }
}

⚠ 关键注意事项

  • 赋值方向勿颠倒:永远是 目标数组[索引] = 源值,而非反向。
  • 避免固定索引填充:用 ArrayList 动态收集再转数组,杜绝 null 占位和 ArrayIndexOutOfBoundsException。
  • 循环边界校验:原代码 for (int i = 0; i stream().max()/min() 或完整遍历 nilai1.length。
  • 平均值逻辑修正:rata 应为 (total1 + total2) / (2 * batas)(两科总分 ÷ 总人数 × 2),而非简单除以 2。
  • 空输入防护:生产环境需增加 try-catch 处理 NumberFormatException 和 NullPointerException。

通过以上修正,程序将准确输出按 KKM 分类的学生名单,且结果数组紧凑、可读性强,彻底解决 null 显示问题。

立即学习Java免费学习笔记(深入)”;

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

254

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1089

2024.03.01

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1010

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

611

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

334

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

235

2025.08.29

length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

954

2023.09.19

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

9

2026.03.11

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

22

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 4.3万人学习

C# 教程
C# 教程

共94课时 | 11.2万人学习

Java 教程
Java 教程

共578课时 | 80.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号