
本文旨在解决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);
关键修改在于:
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 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 = 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程序中商品目录选择顺序错误问题的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/48391.html
微信扫一扫
支付宝扫一扫