我有两段类似的代码:
void task1() {
init();
while(someCondition) {
doSomething();
}
shutdown();
}void task2() {
while(someCondition) {
init();
doSomething();
shutdown();
}
}我希望避免代码重复,我认为这可以通过使用函数式方法来实现。我想把循环和init/shutdown调用放在单独的函数中,然后链接它们的调用(不是Java 8函数接口,更多的是伪代码):
Function setup(Function f){
init();
f();
shutdown();
}Function loop(Function f){
while(someCondition) {
f();
}
}然后我想像这样链接它们:
void task1() {
setup(loop(doSomething));
}void task2() {
loop(setup(doSomething));
}我想过在Java的函数接口中使用compose/andThen,但它们并不合适,因为它们只将一个函数的返回值传递给下一个函数。有没有人知道如何使用Java8或其他方法来做到这一点?
发布于 2020-01-07 21:20:21
你确实可以做到这一点。您需要Runnable,而不是Function,因为您的方法不接受任何参数,也不返回值。如果你的方法有不同的签名,你需要使用另一种类型。
public static void init() { ... }
public static void doSomething() { ... }
public static void shutdown() { ... }
public static Runnable setup(Runnable r) {
return () -> {
init();
r.run();
shutdown();
};
}
public static Runnable loop(Runnable r) {
return () -> {
while (someCondition) {
r.run();
}
};
}
// I used "Main" here because this in a class called Main. Replace "Main" with the name of your class
public static void task1() {
setup(loop(Main::doSomething)).run();
}
public static void task2() {
loop(setup(Main::doSomething)).run();
}还应该注意的是,尽管对于函数式程序员来说,第一个代码看起来可能是“重复的”,但对于Java程序员来说,第一个代码实际上是很好的。以这种方式重写可能会让不习惯函数式风格的人感到更困惑。
https://stackoverflow.com/questions/59629047
复制相似问题