1
我回答这个questionLAMBDA由法嵌套流过滤器与异常
这是代码:
import java.net.NetworkInterface;
import java.net.SocketException;
import java.util.Collections;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
的方法!
private String[] getHostAddresses() {
Set<String> HostAddresses = new HashSet<>();
try {
for (NetworkInterface ni : Collections.list(NetworkInterface.getNetworkInterfaces())) {
if (!ni.isLoopback() && ni.isUp() && ni.getHardwareAddress() != null) {
for (InterfaceAddress ia : ni.getInterfaceAddresses()) {
if (ia.getBroadcast() != null) { //If limited to IPV4
HostAddresses.add(ia.getAddress().getHostAddress());
}
}
}
}
} catch (SocketException e) { }
return HostAddresses.toArray(new String[0]);
}
现在我想使用基于Lamba Stream Java 8进行翻译。 这里我的代码:
try {
Collections.list(NetworkInterface.getNetworkInterfaces())
.stream()
.filter(ni -> !ni.isLoopback()) //unreported exception SocketException; must be caught or declared to be thrown
.filter(ni -> ni.isUp()) //unreported exception SocketException; must be caught or declared to be thrown
.filter(ni -> ni.getHardwareAddress() != null) //unreported exception SocketException; must be caught or declared to be thrown
.flatMap(ni -> ni.getInterfaceAddresses().stream())
.filter(ia -> ia.getBroadcast() != null)
.forEach(ia -> HostAddresses.add(ia.getAddress().getHostAddress()));
} catch (SocketException e) {
System.out.println(e.getMessage());
}
但是当我改变使用尝试捕捉...
try {
Collections.list(NetworkInterface.getNetworkInterfaces())
.stream()
.filter(ni -> { //incompatible types: bad return type in lambda expression missing return value
try {
!ni.isLoopback(); //not a statement cannot find symbol symbol: method isLoopback() location: variable ni of type T where T is a type-variable: T extends Object declared in interface Stream
} catch (SocketException ex) { //exception SocketException is never thrown in body of corresponding try statement
Logger.getLogger(JPanelServerClient.class.getName()).log(Level.SEVERE, null, ex);
}
})
.filter(ni -> ni.isUp())
.filter(ni -> ni.getHardwareAddress() != null)
.flatMap(ni -> ni.getInterfaceAddresses().stream())
.filter(ia -> ia.getBroadcast() != null)
.forEach(ia -> HostAddresses.add(ia.getAddress().getHostAddress()));
} catch (SocketException e) {
System.out.println(e.getMessage());
}
根据提示@雅各布-G该解决的问题(但他有理由以“不是一切必须是功能性的“)
try {
Collections.list(NetworkInterface.getNetworkInterfaces())
.stream()
.filter(ni -> {
try {
return !ni.isLoopback();
} catch (SocketException ex) {
System.out.println(ex.getMessage());
return false;
}
})
.filter(ni -> {
try {
return ni.isUp();
} catch (SocketException ex) {
System.out.println(ex.getMessage());
return false;
}
})
.filter(ni -> {
try {
return ni.getHardwareAddress() != null;
} catch (SocketException ex) {
System.out.println(ex.getMessage());
return false;
}
})
.flatMap(ni -> ni.getInterfaceAddresses().stream())
.filter(ia -> ia.getBroadcast() != null)
.forEach(ia -> HostAddresses.add(ia.getAddress().getHostAddress()));
} catch (SocketException e) {
System.out.println(e.getMessage());
}
我该如何翻译它(更简单)? 我如何翻译它?
**不马虎不得的做法2的功能功能**。为了解决你最后一个例子的问题,把'!ni.isLoopback();'改成'return!ni.isLoopback();'因为'Predicate'必须返回'boolean'。尽管如此,您还需要在异常中返回一个值,或者抛出异常。 –
为使代码更接近功能样式代码,您还可以将带有异常的方法包装在辅助函数中,然后直接在代码的功能部分中使用辅助函数。 – jrook