解决Java程序中商品目录选择时出现的数组越界错误

本文旨在帮助Java开发者解决在商品目录选择程序中,由于用户选择商品顺序不当导致的数组越界错误。通过分析问题代码,找出错误根源,并提供修改后的代码示例,确保程序在用户以任意顺序选择商品时都能正常运行,避免IndexOutOfBoundsError异常的发生。

在开发商品目录选择程序时,经常会遇到用户以非顺序的方式选择商品的情况。如果处理不当,很容易导致数组越界异常,影响程序的健壮性。以下将详细分析问题原因,并提供解决方案。

问题分析

从提供的代码片段可以看出,问题主要出在以下几点:

  1. quantity数组的动态扩展: 使用addD函数动态扩展quantity数组,用于存储用户选择的商品数量。
  2. 商品数量的索引: 在输出商品信息时,使用了quantity[ItemNumber - 1]作为索引来获取商品数量。

当用户按照顺序选择商品时,ItemNumber的值与quantity数组的索引能够对应,程序正常运行。但当用户选择的ItemNumber大于quantity数组的当前长度时,就会发生IndexOutOfBoundsError异常。

解决方案

要解决这个问题,需要确保在访问quantity数组时,使用的索引值始终在其有效范围内。正确的做法是,在添加新的商品数量后,应该访问quantity数组的最后一个元素,而不是依赖于ItemNumber的值。

修改后的代码如下:

{
    System.out.println("How many would you like?\n");
    Scanner myObj = new Scanner(System.in);
    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;
}

代码解释

  • quantity[quantity.length - 1]:使用quantity.length - 1作为索引,访问quantity数组的最后一个元素,即刚刚添加的商品数量。

完整示例代码

为了更好地理解解决方案,以下提供一个完整的示例代码:

import java.util.Scanner;

public class CatalogSelection {

    public static double[] addD(int n, double arr[], double x) {
        int i;
        double newarr[] = new double[n + 

1]; for (i = 0; i < n; i++) newarr[i] = arr[i]; newarr[n] = x; return newarr; } public static void main(String[] args) { String[] name = {"Apple", "Banana", "Orange"}; // 商品名称 double[] quantity = new double[0]; // 商品数量 int ItemNumber; double ItemQuantity; String ItemName; 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"); System.out.println("1. Apple"); System.out.println("2. Banana"); System.out.println("3. Orange"); System.out.println("4. 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]; quantity = addD(quantity.length, quantity, ItemQuantity); System.out.println("\nThe customer picks " + Math.round(quantity[quantity.length - 1]) + " " + ItemName + "(s)\n"); } else if (ItemNumber == 4) { System.out.println("Checkout complete!"); break; } else { System.out.println("Invalid item number. Please try again."); } } while (true); } }

注意事项

  • 在实际开发中,应该使用更健壮的数据结构来存储商品信息和数量,例如使用HashMap,可以避免数组越界问题,并提高代码的可读性和可维护性。
  • 在处理用户输入时,应该进行严格的校验,防止非法输入导致程序崩溃。

总结

通过修改代码中访问quantity数组的索引方式,可以有效解决商品目录选择程序中出现的数组越界错误。同时,建议在实际开发中使用更合适的数据结构和更严格的输入校验,以提高程序的健壮性和用户体验。