Le code suivant fonctionne très bien:Throw RuntimeException dans flux avec Optional.orElseThrow
Stream.of("key1", "key2")
.map(key -> {
SomeObject foo = service.find(key);
if (foo == null) {
throw new RuntimeException("No entity found with key: " + key);
}
return foo;
})
// ...
Cependant, lorsque j'utilise orElseThrow de En option:
Stream.of("key1", "key2")
.map(key -> Optional.ofNullable(someService.find(key))
.orElseThrow(() -> new RuntimeException("No entity found with key: " + key)))
// ...
J'obtiens une erreur de compilation:
Error:(129, 33) java: unreported exception X; must be caught or declared to be thrown
Les deux lancent une RuntimeException, des idées pour lesquelles l'approche avec Optional ne fonctionne pas?
Mise à jour: Mon infrastructure de construction, j'ai essayé de le compiler avec IntelliJ et Maven:
$ mvn -version
Apache Maven 3.3.9 (bb52d8502b132ec0a5a3f4c09453c07478323dc5; 2015-11-10T17:41:47+01:00)
Maven home: C:\Tools\apache-maven-3.3.9
Java version: 1.8.0_91, vendor: Oracle Corporation
Java home: C:\Program Files\Java\jdk1.8.0_91\jre
Default locale: de_AT, platform encoding: Cp1252
OS name: "windows 10", version: "10.0", arch: "amd64", family: "dos"
Quelle version Java utilisez-vous? Pour moi cela fonctionne bien sur Java 8_60 –
Semble être une copie de http://stackoverflow.com/questions/25523375/java8-lambdas-and-exceptions –
Cela a probablement fonctionné pour moi parce que j'ai essayé avec eclipse. Dans la question connexe, ils disent que le bug n'affecte en quelque sorte pas Eclipse. –