首页 > Java > java教程 > 正文

解决Java程序中商品目录选择顺序错误问题

心靈之曲
发布: 2025-09-28 19:40:01
原创
175人浏览过

解决java程序中商品目录选择顺序错误问题

本文旨在解决Java程序中从商品目录选择商品时,由于选择顺序错误导致的程序报错问题。通过分析问题代码,找出数组越界异常的原因,并提供修改后的代码示例,确保程序能够正确处理无序选择商品的情况,并保证商品数量与商品名称的对应关系。

在Java程序开发中,处理用户从商品目录中选择商品时,经常会遇到选择顺序不确定的情况。如果处理不当,可能会导致IndexOutOfBoundsException(数组越界异常)。本文将针对这一问题进行分析,并提供解决方案。

问题分析

原代码中,当用户选择的商品编号ItemNumber与quantity数组的长度不一致时,会发生数组越界错误。 具体来说,quantity数组的长度每次通过addD方法增加1,而ItemNumber是用户输入的商品编号,如果用户先选择商品3,再选择商品1,那么在第一次选择商品3时,quantity数组的长度为0,而ItemNumber - 1 为2, 此时访问quantity[ItemNumber - 1]就会发生数组越界。

解决方案

为了解决这个问题,我们需要确保打印商品信息时,访问的是quantity数组中新增的元素,而不是根据ItemNumber直接访问。

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

修改后的代码如下:

do {
    Scanner myObj = new Scanner(System.in);
    System.out.println("Select the number of the product you would like and once you are finished enter the number to checkout.\n");
    ItemNumber = myObj.nextInt();
    while (ItemNumber <= name.length)
        if (ItemNumber < (name.length + 1)) {
            System.out.println("How many would you like?\n");
            ItemQuantity = myObj.nextDouble();
            ItemName = name[ItemNumber - 1];
            quantity = addD(quantity.length, quantity, ItemQuantity);
            System.out.println("\nThe customer picks " + Math.round(quantity[quantity.length - 1]) + " " + ItemName + "(s)\n");
            break;
        }
} while (ItemNumber <= name.length);
登录后复制

关键修改在于:

商汤商量
商汤商量

商汤科技研发的AI对话工具,商量商量,都能解决。

商汤商量 36
查看详情 商汤商量
System.out.println("\nThe customer picks " + Math.round(quantity[quantity.length - 1]) + " " + ItemName + "(s)\n");
登录后复制

这里使用quantity.length - 1来访问quantity数组的最后一个元素,也就是刚刚添加的商品数量。这样可以避免数组越界异常。

更进一步的优化:使用HashMap存储商品数量

上述方法虽然解决了数组越界的问题,但仍然存在一些潜在的问题。例如,当用户多次选择同一个商品时,quantity数组中会存在多个相同商品的数量,这不利于后续的统计和计算。

更优的解决方案是使用HashMap来存储商品名称和对应的数量。

import java.util.HashMap;
import java.util.Scanner;

public class Catalog {
    public static void main(String[] args) {
        String[] name = {"Product A", "Product B", "Product C"}; // 商品名称数组
        HashMap<String, Double> quantities = new HashMap<>(); // 使用HashMap存储商品名称和数量

        Scanner myObj = new Scanner(System.in);
        int ItemNumber;
        double ItemQuantity;
        String ItemName;

        do {
            System.out.println("Select the number of the product you would like and once you are finished enter the number to checkout.\n");
            for (int i = 0; i < name.length; i++) {
                System.out.println((i + 1) + ". " + name[i]);
            }
            System.out.println((name.length + 1) + ". Checkout");
            ItemNumber = myObj.nextInt();

            if (ItemNumber >= 1 && ItemNumber <= name.length) {
                ItemName = name[ItemNumber - 1];
                System.out.println("How many would you like?\n");
                ItemQuantity = myObj.nextDouble();

                // 更新HashMap中的商品数量
                if (quantities.containsKey(ItemName)) {
                    quantities.put(ItemName, quantities.get(ItemName) + ItemQuantity);
                } else {
                    quantities.put(ItemName, ItemQuantity);
                }

                System.out.println("\nThe customer picks " + ItemQuantity + " " + ItemName + "(s)\n");
            } else if (ItemNumber == name.length + 1) {
                // 结算
                System.out.println("--- Order Summary ---");
                double totalQuantity = 0;
                for (String productName : quantities.keySet()) {
                    double quantity = quantities.get(productName);
                    System.out.println(productName + ": " + quantity);
                    totalQuantity += quantity;
                }
                System.out.println("Total items: " + totalQuantity);
                break;
            } else {
                System.out.println("Invalid product number.\n");
            }
        } while (true);

        myObj.close();
    }
}
登录后复制

这个方案的优点在于:

  • 避免数组越界:不再使用数组来存储商品数量,避免了数组越界的问题。
  • 方便统计:使用HashMap可以方便地统计每个商品的数量。
  • 代码可读性更高:代码逻辑更清晰,易于理解和维护。

注意事项

  • 在使用数组时,务必注意数组的边界,避免数组越界异常。
  • 考虑使用更合适的数据结构来存储数据,例如HashMap,可以提高代码的可读性和可维护性。
  • 在处理用户输入时,需要进行必要的校验,防止用户输入非法数据。

总结

通过修改代码和采用更合适的数据结构,我们可以有效地解决Java程序中商品目录选择顺序错误的问题。在实际开发中,我们需要根据具体情况选择合适的解决方案,并注意代码的可读性和可维护性。 使用HashMap来存储商品信息是更为推荐的做法,它不仅解决了数组越界的问题,还使得代码更加清晰易懂。

以上就是解决Java程序中商品目录选择顺序错误问题的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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