public class PrePostLambdaDemo {
public static void main(String[] args) {
//Need not be declared as final for use within a
//lambda expression, but has to be eventually final.
String outsideOfImpl = "Common Value";
doSomeProcessing("123", (String id, int status) -> {
System.out.println("Finding some data based on"+id);
System.out.println(outsideOfImpl);
System.out.println("Assert that the status is "+status );
});
doSomeProcessing("456", (String id, int status) -> {
System.out.print("Finding data based on id: "+id);
System.out.println(outsideOfImpl);
System.out.println("And updating the status: "+status);
});
}
static void doSomeProcessing(String id, Performer performer ){
System.out.println("Pre-Processing...");
System.out.println("Finding status for given id: "+id);
int status = 2;
performer.performTask(id, status);
System.out.println("Post-processing...");
}
}
interface Performer{
public void performTask(String id, int status);
}
除了有趣的Lambda表达式语法之外,还有一点不同,那就是Lambda表达式外部的变量没有声明成final。但最终变量还是会成为常量,这意味着outsideOfImpl 在声明及初始化之后的值不能被更改。
这个例子只是展示了如何使用清晰明了的Lambda表达式代替匿名内部类。
一个小提示:JDK8的发布时间推迟到了2014年2月,完整的发布时间表可以从这里查阅。我每天都会更新Lambda的构建项目,如果在最新的构建中出现了任何问题,请随时联系我。我会尽最大努力持续构建,并且会在这里发表最新的例子。
另一个提示:不要让Java 8的更新使你不知所措,大部分新特性已经存在于其他编程语言中。我发现学习Lambda表达式的语法和方法可以帮助我以函数式的思维进行思考,对此我还应特别感谢Scala闭包。