答案是使用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<String, Product> 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免费学习笔记(深入)”;
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<Product> getProductsByName(String keyword) { return productMap.values().stream() .filter(p -> p.getName().contains(keyword)) .collect(Collectors.toList()); }
调用示例:
List<Product> results = service.getProductsByName("鼠标"); results.forEach(System.out::println);
提示:对于更复杂场景,可结合数据库(如mysql)+ JDBC或使用spring Boot整合mybatis/JPA实现持久化查询。 基本上就这些。用Java做价格查询,关键是选对数据结构,再封装清晰的查询接口,后续扩展也方便。
评论(已关闭)
评论已关闭