java遍历map

图书日志处理与作者关联
本文介绍了一种处理图书日志数据的方法,通过遍历日志列表并使用服务层接口获取图书及其作者信息,最终将这些信息组织成易于使用的映射结构。
部署运行你感兴趣的模型镜像
Map<String, Map<String, Object>> bookMap = new HashMap<String, Map<String, Object>>();
List<HashMap<String, Object>> loglist = new ArrayList<HashMap<String, Object>>();
loglist = logService.sumGroupByLibrary(libraryId, offset, limit);
int index = 0;
for (HashMap<String, Object> map : loglist) {
Map<String, Object> data = new HashMap<String, Object>();
for (Iterator it = map.entrySet().iterator(); it.hasNext();) {
Map.Entry<String, Object> entry = (Map.Entry<String, Object>) it
.next();
if (entry.getKey().contentEquals("id")) {
Book book = bookService.get(Long.valueOf(entry.getValue()
.toString()));
data.put("book", book);
if (book != null) {
List<Author> authorlist = authorService.findByBook(Long
.valueOf(entry.getValue().toString()));
if (authorlist != null && authorlist.size() > 0) {
data.put("authorList", authorlist);
}
}
}
if (entry.getKey().contentEquals("total")) {
data.put("count", entry.getValue());
}
}
bookMap.put(modelName + index++, data);
}

您可能感兴趣的与本文相关的镜像

Stable-Diffusion-3.5

Stable-Diffusion-3.5

图片生成
Stable-Diffusion

Stable Diffusion 3.5 (SD 3.5) 是由 Stability AI 推出的新一代文本到图像生成模型,相比 3.0 版本,它提升了图像质量、运行速度和硬件效率

Java遍历Map有多种方法,以下为你详细介绍: 1. **for循环 + EntrySet**:使用`for`循环遍历`entrySet`,直接获取键值对。 ```java import java.util.HashMap; import java.util.Map; public class Main { public static void main(String[] args) { Map<Integer, String> map = new HashMap<>(); map.put(1, "value1"); map.put(2, "value2"); for (Map.Entry<Integer, String> entry : map.entrySet()) { System.out.println("key = " + entry.getKey() + ", value = " + entry.getValue()); } } } ``` 这种方法将Map中的每个键值对封装成一个`Map.Entry`对象,通过`entrySet()`方法获取所有的`Map.Entry`对象集合,然后使用`for-each`循环遍历这个集合,直接访问每个键值对的键和值,效率较高,代码简洁,是比较常用的遍历方式之一 [^1]。 2. **Iterator + EntrySet**:使用迭代器遍历`entrySet`,可以在遍历过程中进行删除操作。 ```java import java.util.HashMap; import java.util.Iterator; import java.util.Map; public class Main { public static void main(String[] args) { Map<Integer, String> map = new HashMap<>(); map.put(1, "value1"); map.put(2, "value2"); Iterator<Map.Entry<Integer, String>> iterator = map.entrySet().iterator(); while (iterator.hasNext()) { Map.Entry<Integer, String> entry = iterator.next(); System.out.println("key = " + entry.getKey() + ", value = " + entry.getValue()); } } } ``` 此方法通过`entrySet()`方法获取一个包含所有键值对的`Set`集合,然后通过迭代器依次访问每个键值对。迭代器提供了`remove()`方法,可以在遍历过程中安全地删除元素,避免了`ConcurrentModificationException`异常,适合需要在遍历过程中进行元素删除操作的场景 [^1][^4]。 3. **for循环 + KeySet(效率低)**:使用`for`循环遍历`keySet`,再通过键获取值。 ```java import java.util.HashMap; import java.util.Map; public class Main { public static void main(String[] args) { Map<Integer, String> map = new HashMap<>(); map.put(1, "value1"); map.put(2, "value2"); for (Integer key : map.keySet()) { System.out.println("key = " + key + ", value = " + map.get(key)); } } } ``` 该方法先通过`keySet()`方法获取Map中所有键的集合,然后使用`for-each`循环遍历这个集合,对于每个键,通过`map.get(key)`方法获取对应的值。由于每次获取值都需要进行一次查找操作,效率相对较低,尤其是在Map元素较多的情况下 [^1][^3]。 4. **Iterator + KeySet(效率低)**:使用迭代器遍历`keySet`,再通过键获取值。 ```java import java.util.HashMap; import java.util.Iterator; import java.util.Map; public class Main { public static void main(String[] args) { Map<Integer, String> map = new HashMap<>(); map.put(1, "value1"); map.put(2, "value2"); Iterator<Integer> iterator = map.keySet().iterator(); while (iterator.hasNext()) { Integer key = iterator.next(); System.out.println("key = " + key + ", value = " + map.get(key)); } } } ``` 此方法与`for循环 + KeySet`类似,先通过`keySet()`方法获取所有键的集合,然后使用迭代器遍历这个集合,对于每个键,通过`map.get(key)`方法获取对应的值。同样,由于每次获取值都需要进行查找操作,效率相对较低,并且可以在遍历过程中使用迭代器的`remove()`方法删除元素 [^1]。 5. **lambda表达式(推荐)**:使用Lambda表达式进行遍历,代码简洁。 ```java import java.util.HashMap; import java.util.Map; public class Main { public static void main(String[] args) { Map<Integer, String> map = new HashMap<>(); map.put(1, "value1"); map.put(2, "value2"); map.forEach((key, value) -> System.out.println("key = " + key + ", value = " + value)); } } ``` 从Java 8开始引入了`forEach`方法,它接受一个`BiConsumer`函数式接口作为参数。通过Lambda表达式可以简洁地定义这个函数式接口的实现,直接对每个键值对进行操作。这种方法代码简洁,易于理解,适合在Java 8及以上版本中使用 [^1]。 6. **Stream流**:使用Stream API进行遍历,可以进行更多的操作。 ```java import java.util.HashMap; import java.util.Map; public class Main { public static void main(String[] args) { Map<Integer, String> map = new HashMap<>(); map.put(1, "value1"); map.put(2, "value2"); map.entrySet().stream() .forEach(entry -> System.out.println("key = " + entry.getKey() + ", value = " + entry.getValue())); } } ``` Java 8引入的Stream API提供了强大的流式处理能力。通过`entrySet().stream()`方法将Map的键值对集合转换为一个流,然后使用`forEach`方法对每个键值对进行操作。Stream API还可以进行过滤、映射、排序等操作,适合需要对Map中的元素进行复杂处理的场景 [^1]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值