3 回答
![?](http://img1.sycdn.imooc.com/5333a1d100010c2602000200-100-100.jpg)
TA贡献1831条经验 获得超10个赞
您可以迭代地图中的一组值,并过滤以返回匹配产品的列表:
public List<Product> getProductByCategory(String category) {
if(products.size() == 0){
return new ArrayList<>();
}
return this.products.values().stream()
.filter(product -> product.getCategory().equals(category))
.collect(Collectors.toList());
}
您还可以为此使用 for 循环:
public List<Product> getProductByCategory(String category) {
List<Product> ret = new ArrayList<>();
if(products.size() == 0){
return ret;
}
for(Product p: this.products.values()) {
if(p.getCategory().equals(category))
ret.add(p);
}
return ret;
}
请注意,ArrayList如果产品地图为空,我将返回一个空值。这是集合返回类型的更好做法(而不是返回null)
![?](http://img1.sycdn.imooc.com/5458477300014deb02200220-100-100.jpg)
TA贡献1846条经验 获得超7个赞
一种方法是遍历 Hashmap 如下:
public List<Product> getProductsBasedOnCategory(String category)
{
List<Product> list = new ArrayList<Product>();
if (products.size()<=0) {
return list;
}
products.entrySet().stream().forEach((entry) -> {
if (((Product) entry.getValue()).getCategory().equals(category)) {
list.add(entry.getValue())
}
});
return list;
}
![?](http://img1.sycdn.imooc.com/545863c10001865402200220-100-100.jpg)
TA贡献1757条经验 获得超8个赞
您至少有 2 个选项,例如。
为您要搜索的每个字段准备一张特定的地图。如果您有很多对象,这会更快,因为在地图中搜索需要 O(1) 而遍历整个集合需要 O(N)。大 O 备忘单
声明地图
private Map<Long, Product> productsByID = new HashMap();
private Map<String, Product> productsByCategory = new HashMap();
初始化地图
public ProductDaoImpl()
{
// Create the objects
Product p1 = new Product(1L,"TV","Entertinement",10000F,250L,"This is best TV!");
Product p2 = new Product(2L,"Computer","Technology",20000F,350L,"My Computer name Hp and SONY ViVo!");
Product p3 = new Product(3L,"DeskTopComputer","Technology",15000F,150L,"My Desktop Computer name Accer and SONY ViVo!");
//Assign the objects into the map by ids
productsByID.put(1L, p1);
productsByID.put(2L, p2);
productsByID.put(3L, p3);
//Assign the objects into the map by category
productsByCategory.put(p1.getCategory(), p1);
productsByCategory.put(p2.getCategory(), p2);
productsByCategory.put(p3.getCategory(), p3);
}
使用您拥有的相同地图,并按照其他答案的解释几乎遍历所有值。
最后,我不知道这是否只是一个练习代码并且您的值很少,在这种情况下,性能无关紧要,或者这是您的生产代码的开始,在这种情况下,您希望得到很多值。如果最新的是真的,可能您想将其建模为数据库(sql 或非 sql)并按您想要/需要的特定字段进行查询。
添加回答
举报