登录
首页 >  文章 >  java教程

函数中动态创建类实例对比数据方法

时间:2026-02-16 09:19:00 463浏览 收藏

本文深入探讨了在Java中如何通过在函数调用过程中动态创建内部类实例并持久化存储于外部集合(如ArrayList)中,实现多轮用户输入数据的跨调用对比分析——尤其聚焦于相邻两次电量(battery)值的差值检测与条件输出,既解决了局部变量生命周期限制导致的数据丢失问题,又通过清晰的职责分离(采集 vs 分析)、规范的命名、健壮的输入处理和直观的结果呈现,为实时监控类场景(如设备电量突变预警)提供了可直接运行、易维护、符合面向对象设计原则的完整解决方案。

如何在函数中动态创建并管理多个类实例以实现跨调用数据比较

本文讲解如何在Java中通过集合(如ArrayList)持久化保存多次函数调用生成的内部类对象,并基于这些对象的字段(如battery)进行相邻值差值判断与条件输出,解决多轮用户输入下的实时比较需求。

要实现在多次调用 func() 时分别创建不同对象、并在后续统一比较它们的 battery 值(例如检测相邻两次输入的电量差是否 >1),关键在于将每次创建的对象“记住”——即存储到一个外部可访问的集合中,而非仅限于函数局部作用域。

以下是完整、可运行的优化实现(已修正命名规范、逻辑结构与健壮性):

import java.util.*;

public class Outer { // ✅ 类名首字母大写(原 'Out' → 'Outer';避免使用 'in' 作类名)

    private Scanner sc = new Scanner(System.in);
    private List<Inner> history = new ArrayList<>(); // ✅ 外部集合,持久保存所有实例

    // ✅ 内部类重命名为 Inner(驼峰+大写首字母)
    private static class Inner {
        final int battery; // ✅ 使用有意义的字段名
        final int time;
        Inner(int battery, int time) {
            this.battery = battery;
            this.time = time;
        }
    }

    public void func() {
        System.out.print("Enter battery and time: ");
        if (sc.hasNextInt()) {
            int battery = sc.nextInt();
            int time = sc.nextInt();
            history.add(new Inner(battery, time)); // ✅ 每次创建后立即存入集合
        } else {
            System.out.println("Invalid input. Skipping.");
            sc.next(); // 清除非法输入
        }
    }

    // ✅ 新增:执行全部比较与输出逻辑(应在所有 func() 调用完成后调用)
    public void analyzeAndPrint() {
        if (history.size() < 2) {
            System.out.println("At least two entries needed for comparison.");
            return;
        }

        System.out.println("\nBattery drops > 1 detected:");
        // 遍历相邻对:第0&1、1&2、2&3...
        for (int i = 0; i < history.size() - 1; i++) {
            int currBattery = history.get(i).battery;
            int nextBattery = history.get(i + 1).battery;
            int diff = currBattery - nextBattery; // 注意:是当前减下一个(下降量)

            if (diff > 1) {
                Inner curr = history.get(i);
                System.out.printf("Call %d: battery=%d, time=%d → drop of %d to next%n", 
                    i + 1, curr.battery, curr.time, diff);
            }
        }
    }

    // ✅ 示例主流程(演示4次调用)
    public static void main(String[] args) {
        Outer outer = new Outer();
        // 模拟4次输入(实际运行时用户手动输入)
        // 输入序列:98 2 ↵ 97 4 ↵ 95 9 ↵ 94 11 ↵
        for (int i = 0; i < 4; i++) {
            outer.func();
        }
        outer.analyzeAndPrint();
    }
}

关键要点说明:

  • 集合存储是核心:history 列表在类成员级别声明,生命周期覆盖所有 func() 调用,确保对象不被丢弃;
  • 命名规范提升可读性与专业性:Outer/Inner 替代 Out/in,字段名 battery/time 明确语义;
  • 比较逻辑清晰:遍历 history 相邻索引对,计算 battery[i] - battery[i+1] > 1,符合题设“2nd与3rd差值大于1则输出2nd”的要求;
  • 健壮性增强:添加输入校验、空集合保护、格式化输出,便于调试与实际部署;
  • ⚠️ 注意:func() 仅负责采集与存储,比较逻辑必须分离到独立方法(如 analyzeAndPrint())中执行——这是面向对象设计的基本原则,避免在输入过程中混杂业务判断。

运行上述代码并按示例输入,将准确输出:

Call 2: battery=97, time=4 → drop of 2 to next

这正是题目所求的“第2次调用的 battery=97 及其 time=4”。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于文章的相关知识,也可关注golang学习网公众号。

资料下载
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>