Map<String, ApprovedSaleData> dapartMap = approvedSaleDataList.stream() .collect(Collectors.toMap(ApprovedSaleData::getDepartment, item -> item)); 怎么避免getDepartment值为空报空指针
时间: 2024-02-21 22:00:37 浏览: 7
你可以在使用 `Collectors.toMap()` 方法之前,使用 `filter()` 方法过滤掉 `getDepartment()` 方法返回 `null` 值的元素。例如:
```
Map<String, ApprovedSaleData> dapartMap = approvedSaleDataList.stream()
.filter(item -> item.getDepartment() != null)
.collect(Collectors.toMap(ApprovedSaleData::getDepartment, item -> item));
```
这样就可以避免 `getDepartment()` 返回 `null` 值导致的空指针异常。
相关问题
Map<String, ApprovedSaleData> dapartMap = approvedSaleDataList.stream() .collect(Collectors.toMap(ApprovedSaleData::getDepartment, item -> item)); 这段代码怎么防止空指针异常
可以在Lambda表达式中进行空指针判断。例如,可以使用Optional类的ofNullable方法将item包装成Optional对象,然后使用orElse方法指定默认值,以防止空指针异常。修改后的代码如下:
```
Map<String, ApprovedSaleData> dapartMap = approvedSaleDataList.stream()
.collect(Collectors.toMap(ApprovedSaleData::getDepartment, item -> Optional.ofNullable(item).orElse(new ApprovedSaleData())));
```
在上述代码中,如果item为null,则Optional.ofNullable(item)返回一个空的Optional对象。然后我们使用orElse方法指定了一个默认值new ApprovedSaleData(),以确保在item为null的情况下,也能够将一个默认值放入Map中。
Map<String, List<TBmwyResolvedevicedata>> map = dataList.stream().collect(Collectors.groupingBy(TBmwyResolvedevicedata::getEndTime)); 用冒泡排序对key大小排序
可以使用冒泡排序算法对Map中的key进行排序,具体步骤如下:
1. 将Map中的key转换为一个List集合;
2. 对List集合进行冒泡排序,按照key的大小进行比较排序;
3. 根据排好序的List集合,遍历Map,将key按照排好的顺序放入一个新的LinkedHashMap中;
4. 最后,将新的LinkedHashMap返回即可。
下面是示例代码实现:
```java
Map<String, List<TBmwyResolvedevicedata>> map = dataList.stream().collect(Collectors.groupingBy(TBmwyResolvedevicedata::getEndTime));
List<String> keys = new ArrayList<>(map.keySet());
for (int i = 0; i < keys.size() - 1; i++) {
for (int j = 0; j < keys.size() - i - 1; j++) {
if (keys.get(j).compareTo(keys.get(j + 1)) > 0) {
Collections.swap(keys, j, j + 1);
}
}
}
LinkedHashMap<String, List<TBmwyResolvedevicedata>> sortedMap = new LinkedHashMap<>();
for (String key : keys) {
sortedMap.put(key, map.get(key));
}
// sortedMap即为按照key排序后的Map
```