
本文旨在帮助Java开发者解决在商品目录选择程序中,由于用户选择商品顺序不当导致的数组越界错误。通过分析问题代码,找出错误根源,并提供修改后的代码示例,确保程序在用户以任意顺序选择商品时都能正常运行,避免IndexOutOfBoundsError异常的发生。
在开发商品目录选择程序时,经常会遇到用户以非顺序的方式选择商品的情况。如果处理不当,很容易导致数组越界异常,影响程序的健壮性。以下将详细分析问题原因,并提供解决方案。
问题分析
从提供的代码片段可以看出,问题主要出在以下几点:
立即学习“Java免费学习笔记(深入)”;
quantity数组的动态扩展: 使用addD函数动态扩展quantity数组,用于存储用户选择的商品数量。商品数量的索引: 在输出商品信息时,使用了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 = 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数组的索引方式,可以有效解决商品目录选择程序中出现的数组越界错误。同时,建议在实际开发中使用更合适的数据结构和更严格的输入校验,以提高程序的健壮性和用户体验。
以上就是解决Java程序中商品目录选择时出现的数组越界错误的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/48636.html
微信扫一扫
支付宝扫一扫