答案是使用HashMap存储商品信息并提供按ID查询价格的方法。定义Product类封装商品属性,通过PriceQueryService将商品ID作为键存入HashMap实现高效查找,提供getPriceById方法返回价格,支持按名称模糊查询,并可在主程序中调用验证结果,适用于简单场景,复杂应用可结合数据库扩展。

要实现商品价格查询功能,核心是设计合理的数据结构和查询逻辑。Java提供了多种方式来完成这项任务,下面从数据存储、查询方法到实际代码一步步说明。
1. 定义商品类
每个商品应包含名称、编号和价格等基本信息。创建一个简单的POJO类来表示商品。
public class Product {
private String id;
private String name;
private double price;
public Product(String id, String name, double price) {
this.id = id;
this.name = name;
this.price = price;
}
// Getter方法
public String getId() { return id; }
public String getName() { return name; }
public double getPrice() { return price; }
@Override
public String toString() {
return "Product{" +
"id='" + id + '\'' +
", name='" + name + '\'' +
", price=" + price +
'}';
}
}
2. 使用Map存储商品信息
使用HashMap以商品ID为键存储商品,能实现快速查找。这是最常见且高效的方式。
import java.util.HashMap;
import java.util.Map;
public class PriceQueryService {
private Map productMap;
public PriceQueryService() {
productMap = new HashMap<>();
// 模拟初始化数据
productMap.put("P001", new Product("P001", "笔记本电脑", 5999.0));
productMap.put("P002", new Product("P002", "无线鼠标", 129.0));
productMap.put("P003", new Product("P003", "机械键盘", 499.0));
}
}
3. 实现价格查询方法
提供按商品ID查询价格的方法,返回结果可以是价格值或完整商品对象,也可处理不存在的情况。
立即学习“Java免费学习笔记(深入)”;
BJXShop网上购物系统是一个高效、稳定、安全的电子商店销售平台,经过近三年市场的考验,在中国网购系统中属领先水平;完善的订单管理、销售统计系统;网站模版可DIY、亦可导入导出;会员、商品种类和价格均实现无限等级;管理员权限可细分;整合了多种在线支付接口;强有力搜索引擎支持... 程序更新:此版本是伴江行官方商业版程序,已经终止销售,现于免费给大家使用。比其以前的免费版功能增加了:1,整合了论坛
public Double getPriceById(String productId) {
Product product = productMap.get(productId);
if (product != null) {
return product.getPrice();
} else {
return null; // 或抛出自定义异常
}
}
public Product getProductById(String productId) {
return productMap.get(productId);
}
在主程序中调用:
public class Main {
public static void main(String[] args) {
PriceQueryService service = new PriceQueryService();
String targetId = "P001";
Double price = service.getPriceById(targetId);
if (price != null) {
System.out.println("商品价格: " + price);
} else {
System.out.println("商品未找到");
}
}
}
4. 扩展:支持按名称模糊查询
若需根据商品名称查找,可遍历map的值集合,使用contains进行模糊匹配。
public List getProductsByName(String keyword) {
return productMap.values().stream()
.filter(p -> p.getName().contains(keyword))
.collect(Collectors.toList());
}
调用示例:
List提示:对于更复杂场景,可结合数据库(如MySQL)+ JDBC或使用Spring Boot整合MyBatis/JPA实现持久化查询。 基本上就这些。用Java做价格查询,关键是选对数据结构,再封装清晰的查询接口,后续扩展也方便。results = service.getProductsByName("鼠标"); results.forEach(System.out::println);









