
在许多业务场景中,数据往往被分散存储在不同的结构中。例如,商品的基本信息(如名称和单价)可能存储在两个独立的数组中,而用户的订单详情则可能以二维数组的形式存在,其中包含商品在商品列表中的索引及其购买数量。
考虑以下Java代码示例,它定义了商品名称 (NAMES) 和净价格 (NETPRICES) 两个静态常量数组,以及一个模拟的用户订单 (Order) 二维数组:
public class Ex1_19 {
// 商品名称数组
final static String NAMES[]= {"Spa reine 25 ","Bru plate 50","Bru pét 50", /* ... 其他商品名称 ... */ "Tagl saum"};
// 商品净价格数组
final static double NETPRICES[]= {2.2, 2.3,3.9,2.2,2.2,2.6,2.6,2.6,2.6,2.6,2.6,4.5,2.2,2.2,2.2,2.5,2.5,7.0,7.0,2.8,2.8,6.2,6.2,6.2,6.2,
2.9,5.5,2.7,5.1,3.1,5.8,2.6,4.9,2.6,4.9,10.8,11.2,12.2,14.5,16.9};
public static void main(String[] args) {
// 订单数组:每个子数组包含 [商品索引, 购买数量]
// 注意:这里的商品索引是基于1的,而不是Java数组常用的0-based索引
int Order[][]={{3,2},{1,3},{12,4},{37,1},{36,3},{0,0},{0,0},{0,0}, {0,0}};
previewOrder(Order);
}
// 订单预览方法,需要将Order数组中的信息与NAMES和NETPRICES数组关联起来
public static void previewOrder(int order[][]) {
// 方法实现将在后续章节详细讲解
}
}我们的目标是编写 previewOrder 方法,它接收 Order 数组作为参数,并根据 Order 数组中的商品索引和数量,从 NAMES 和 NETPRICES 数组中获取相应的信息,最终输出每项订单的详细内容,包括商品名称、单价、数量和总价。
预期的输出格式大致如下: Bru pét 50 3.9 2 7.80Spa reine 25 2.2 3 6.60 ...以此类推。
在上述订单场景中,一个关键的挑战是 Order 数组中存储的商品索引是基于1的,而不是Java数组默认的0-based索引。例如,Order[0] 中的 {3,2} 表示购买索引为 3 的商品,数量为 2。然而,在 NAMES 和 NETPRICES 数组中,索引 3 实际上对应的是第四个元素。因此,在访问 NAMES 和 NETPRICES 数组时,我们需要将 Order 数组中的索引值减去1。
为了正确处理订单数据并生成预期的输出,previewOrder 方法需要遍历 Order 数组,对每个订单项进行处理。
立即学习“Java免费学习笔记(深入)”;
public class Ex1_19 {
// ... (NAMES 和 NETPRICES 数组定义同上) ...
public static void main(String[] args) {
int Order[][]={{3,2},{1,3},{12,4},{37,1},{36,3},{0,0},{0,0},{0,0}, {0,0}};
previewOrder(Order);
}
/**
* 预览订单详情,将订单信息与商品名称和价格关联。
*
* @param order 二维数组,每个子数组包含 [基于1的商品索引, 购买数量]
*/
public static void previewOrder(int order[][]) {
// 遍历订单数组的每一行,每一行代表一个订单项
for (int i = 0; i < order.length; i++) {
// 获取基于1的商品索引,并将其转换为0-based索引
int itemIndex = order[i][0];
int adjustedIndex = itemIndex - 1; // 转换为0-based索引
// 获取购买数量
int amount = order[i][1];
// 忽略无效订单项(例如,商品索引为0或数量为0的占位符)
if (itemIndex == 0 || amount == 0) {
continue;
}
// 重要的边界检查:确保调整后的索引在NAMES和NETPRICES数组的有效范围内
// 避免 ArrayIndexOutOfBoundsException
if (adjustedIndex < 0 || adjustedIndex >= NAMES.length || adjustedIndex >= NETPRICES.length) {
System.err.println("警告:订单项 " + itemIndex + " 对应的商品索引无效,已跳过。");
continue;
}
// 从NAMES数组中获取商品名称
String name = NAMES[adjustedIndex];
// 从NETPRICES数组中获取商品单价
double price = NETPRICES[adjustedIndex];
// 计算当前订单项的总价
double total = amount * price;
// 格式化并打印输出结果
// 使用 String.format 可以更好地控制浮点数的精度和格式
System.out.printf("%s %.2f %d %.2f%n", name, price, amount, total);
}
}
}代码解释:
命名约定: 在Java中,变量名通常以小写字母开头,例如 order 而不是 Order。虽然在此示例中 Order 是一个参数名,但遵循约定可以提高代码可读性。
PHP经典实例(第2版)能够为您节省宝贵的Web开发时间。有了这些针对真实问题的解决方案放在手边,大多数编程难题都会迎刃而解。《PHP经典实例(第2版)》将PHP的特性与经典实例丛书的独特形式组合到一起,足以帮您成功地构建跨浏览器的Web应用程序。在这个修订版中,您可以更加方便地找到各种编程问题的解决方案,《PHP经典实例(第2版)》中内容涵盖了:表单处理;Session管理;数据库交互;使用We
453
数组越界: 始终要警惕数组越界异常 (ArrayIndexOutOfBoundsException)。在从外部输入或转换索引时,务必进行边界检查,以保证程序的健壮性。
数据模型优化: 对于更复杂的应用,将商品名称和价格分别存储在两个数组中可能不是最佳实践。更好的方法是创建一个 Product 类,包含 name 和 price 属性,然后使用 Product 对象的数组或列表。这样可以更好地封装相关数据,提高代码的可维护性和可扩展性。
// 示例 Product 类
class Product {
String name;
double price;
public Product(String name, double price) {
this.name = name;
this.price = price;
}
// ... getters ...
}
// 然后可以有一个 Product[] products 数组
// Order 数组中存储的索引直接对应 products 数组的索引循环选择: 尽管原问题提及 while 循环,但对于已知迭代次数的数组遍历,for 循环通常更为简洁和推荐。如果严格要求 while 循环,可以这样实现:
// while 循环实现示例
// int i = 0;
// while (i < order.length) {
// // ... 内部逻辑与 for 循环相同 ...
// i++;
// }但 for 循环在初始化、条件判断和增量步进方面更集中,可读性更佳。
本教程通过一个具体的订单预览案例,详细演示了如何在Java中有效地利用多个数组来处理和整合数据。核心要点包括:
掌握这些技巧将有助于您在Java编程中更灵活、更安全地处理各种数组操作。在实际开发中,根据项目的复杂度和规模,可以考虑采用更高级的数据结构和面向对象的设计模式来进一步优化数据管理。
以上就是Java中多数组协作处理订单数据与索引管理教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号