
本文旨在解决Java程序中,用户从商品目录中选择商品时,由于选择顺序不固定导致的数组越界错误。通过分析问题代码,找出错误原因,并提供修改后的代码示例,确保程序在用户以任意顺序选择商品时都能正常运行,并输出正确的商品数量信息。
在开发商品目录选择程序时,经常会遇到用户不按顺序选择商品的情况。这可能导致程序出现数组越界(IndexOutOfBoundsError)的错误。以下将详细分析问题代码,并提供解决方案。
问题分析
原代码中,主要问题在于以下几点:
立即学习“Java免费学习笔记(深入)”;
quantity数组的增长方式: 使用addD方法动态增加quantity数组的大小,但并没有考虑到用户选择商品的顺序。如果用户先选择商品3,再选择商品1,那么在quantity数组中,商品3的数量会被添加到数组的末尾,而商品1的数量还没有被添加。
输出时的索引错误: 在输出语句中,quantity[ItemNumber – 1]被用来获取商品数量。如果ItemNumber大于quantity数组的当前长度,就会发生数组越界错误。
解决方案
为了解决这个问题,我们需要改进quantity数组的管理方式,并确保在输出时使用正确的索引。以下是一种可能的解决方案:
使用HashMap存储商品数量: 使用HashMap来存储商品名称和对应的数量。HashMap可以根据商品名称直接查找对应的数量,而不需要依赖于数组的索引。
动态更新HashMap中的商品数量: 当用户选择商品时,首先检查HashMap中是否已经存在该商品。如果存在,则增加商品的数量;如果不存在,则将商品添加到HashMap中,并设置初始数量。
输出时从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 = 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来存储商品数量,可以有效地解决用户不按顺序选择商品导致的数组越界问题。这种方法更加灵活,并且可以方便地扩展到更复杂的商品目录选择程序中。该方案避免了直接使用数组索引,降低了出错的概率,提高了代码的健壮性。
以上就是解决Java程序中商品目录选择顺序错误导致的数组越界问题的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/48370.html
微信扫一扫
支付宝扫一扫