在Java 8及更高版本中,Lambda表達式不支持使用try-catch語句
方法1:使用函數式接口包裝異常
創建一個新的函數式接口,該接口允許拋出異常。然后,將Lambda表達式包裝在這個接口的實現中。例如,你可以創建一個名為ExceptionalFunction
的接口:
@FunctionalInterface
public interface ExceptionalFunction<T, R, E extends Exception> {
R apply(T t) throws E;
}
然后,你可以使用這個接口來包裝可能拋出異常的Lambda表達式:
ExceptionalFunction<String, Integer, NumberFormatException> toInt = (s) -> Integer.parseInt(s);
方法2:使用Optional和Streams處理異常
通過使用Optional類和Streams API,你可以在處理異常時避免顯式地使用null值或特定的默認值。例如,你可以使用Optional.map()
方法將一個可能拋出異常的函數應用于一個Optional對象:
Optional<String> optionalString = Optional.of("123");
Optional<Integer> optionalInt = optionalString.map(s -> {
try {
return Integer.parseInt(s);
} catch (NumberFormatException e) {
return null;
}
});
方法3:使用自定義工具方法處理異常
你還可以編寫一個自定義工具方法,該方法接受一個可能拋出異常的Lambda表達式,并返回一個包裝了異常處理邏輯的新Lambda表達式。例如:
public static <T, R> Function<T, R> handleException(ExceptionalFunction<T, R, ? extends Exception> function) {
return t -> {
try {
return function.apply(t);
} catch (Exception e) {
// 處理異常,例如記錄日志、返回默認值等
return null;
}
};
}
然后,你可以使用這個工具方法來處理可能拋出異常的Lambda表達式:
List<String> strings = Arrays.asList("1", "2", "three");
List<Integer> integers = strings.stream()
.map(handleException(s -> Integer.parseInt(s)))
.collect(Collectors.toList());
請注意,這些方法都有其優缺點。在選擇最佳方法時,請根據你的具體需求和場景進行權衡。