解决Java程序中商品目录选择顺序错误导致的数组越界问题

本文旨在解决Java程序中,用户从商品目录中选择商品时,由于选择顺序不固定导致的数组越界错误。通过分析问题代码,找出错误原因,并提供修改后的代码示例,确保程序在用户以任意顺序选择商品时都能正常运行,并输出正确的商品数量信息。

在开发商品目录选择程序时,经常会遇到用户不按顺序选择商品的情况。这可能导致程序出现数组越界(IndexOutOfBoundsError)的错误。以下将详细分析问题代码,并提供解决方案。

问题分析

原代码中,主要问题在于以下几点:

  1. quantity数组的增长方式: 使用addD方法动态增加quantity数组的大小,但并没有考虑到用户选择商品的顺序。如果用户先选择商品3,再选择商品1,那么在quantity数组中,商品3的数量会被添加到数组的末尾,而商品1的数量还没有被添加。

  2. 输出时的索引错误: 在输出语句中,quantity[ItemNumber - 1]被用来获取商品数量。如果ItemNumber大于quantity数组的当前长度,就会发生数组越界错误。

解决方案

为了解决这个问题,我们需要改进quantity数组的管理方式,并确保在输出时使用正确的索引。以下是一种可能的解决方案:

  1. 使用HashMap存储商品数量: 使用HashMap来存储商品名称和对应的数量。HashMap可以根据商品名称直接查找对应的数量,而不需要依赖于数组的索引。

  2. 动态更新HashMap中的商品数量: 当用户选择商品时,首先检查HashMap中是否已经存在该商品。如果存在,则增加商品的数量;如果不存在,则将商品添加到HashMap中,并设置初始数量。

  3. 输出时从HashMap中获取商品数量: 在输出语句中,使用商品名称从HashMap中获取对应的数量。

代码示例

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

public class CatalogSelection {

    public static void main(String[] args) {
        String[] name = {"Product A", "Product B", "Product C"}; // 商品名称数组
        HashMap quantityMap = 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) {
                System.out.println("How many would you like?\n");
                ItemQuantity = myObj.nextDouble();
                ItemName = name[ItemNumber - 1];

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

                System.out.println("\nThe customer picks " + Math.round(quantityMap.get(ItemName)) + " " + ItemName + "(s)\n");
            } else if (ItemNumber == name.length + 1) {
                System.out.println("Checkout");
                break;
            } else {
                System.out.println("Invalid item number. Please try again.");
            }
        } while (true);

        myObj.close();
    }
}

代码解释

  • 使用HashMap quantityMap 来存储商品名称和数量。
  • 用户输入商品编号后,根据编号从 name 数组中获取商品名称。
  • 使用 quantityMap.containsKey(ItemName) 检查 HashMap 中是否已存在该商品。
  • 如果存在,则使用 quantityMap.put(

    ItemName, quantityMap.get(ItemName) + ItemQuantity) 更新数量。
  • 如果不存在,则使用 quantityMap.put(ItemName, ItemQuantity) 添加新的商品和数量。
  • 输出时,使用 quantityMap.get(ItemName) 从 HashMap 中获取商品数量。

注意事项

  • 在实际应用中,可能需要对用户输入进行更严格的校验,例如检查输入是否为数字,以及数字是否在有效范围内。
  • 可以使用更复杂的数据结构来存储商品信息,例如包含商品名称、价格、描述等。

总结

通过使用HashMap来存储商品数量,可以有效地解决用户不按顺序选择商品导致的数组越界问题。这种方法更加灵活,并且可以方便地扩展到更复杂的商品目录选择程序中。该方案避免了直接使用数组索引,降低了出错的概率,提高了代码的健壮性。