我在一个环境中工作,其中通过调用远程服务而不是使用数据库来执行大量日常脚本任务。
对于许多脚本编写任务,我经常使用Groovy,而Groovy专门用于该任务的最有用的功能之一就是它是用流畅的Builders构建的 。
现在,Groovy构建器利用了一些Groovy语言功能,这些功能永远都不会融入Java中。
最值得注意的是,Groovy构建器利用了Groovy的Meta编程功能,而Java不久就不会使用它。
但是,Groovy构建器具有的一个关键功能是其层次结构构建方法。
这使构建者可以整洁安全地创建嵌套树状结构,这些结构可用于对从UX表单布局到XML的所有内容进行建模。
这种方法至少可以使用Java 8 lambda表达式相当简洁地建模。
对于我的示例,我决定采用一个相当简单的Maven pom文件,并查看是否可以创建一个构建器来处理该文件。
对于制造商的所有代码可在Github 这里 。
pom.xml文件如下:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.github</groupId>
<artifactId>lambda-builder</artifactId>
<version>1.0-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.11</version>
</dependency>
<dependency>
<groupId>commons-beanutils</groupId>
<artifactId>commons-beanutils</artifactId>
<version>1.7.0</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>1.8</source>
<target>1.8</target>
<fork>true</fork>
<compilerArgument>-proc:none</compilerArgument>
</configuration>
</plugin>
</plugins>
</build>
</project>
这是构建器构建此模型的示例代码:
MarkupBuilder pom = new XmlMarkupBuilder(true, "pom")
.at("xmlns", "http://maven.apache.org/POM/4.0.0")
.at("xmlns:xsi", "http://www.w3.org/2001/XMLSchema-instance")
.at("xsi:schemaLocation", "http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd");
pom.el("modelVersion", "4.0.0");
pom.el("groupId", "com.github");
pom.el("artifactId", "lambda-builder");
pom.el("version", "1.0-SNAPSHOT");
pom.el("dependencies", () -> {
pom.el("dependency", () -> {
pom.el("groupId", "junit");
pom.el("artifactId", "junit");
pom.elx("version", version::get);
});
pom.el("dependency", () -> {
pom.el("groupId", "commons-beanutils");
pom.el("artifactId", "commons-beanutils");
pom.elx("version", version::get);
});
});
pom.el("build", () -> {
pom.el("plugins", () -> {
pom.el("plugin", () -> {
pom.el("groupId", "org.apache.maven.plugins");
pom.el("artifactId", "maven-compiler-plugin");
pom.el("configuration", () -> {
pom.el("source", 1.8);
pom.el("target", 1.8);
pom.el("fork", true);
pom.el("compilerArgument", "-proc:none");
});
});
});
});
有关此方面的一些注意事项:
- 我为某些方法创建了一种特殊形式,该方法将java.util.function.Supplier作为参数,并允许您延迟对值的求值,直到遍历构建器为止。
- 我避免使用方法链接(尽管我在构建器中迎合了它)。 尝试这两种方法,我个人觉得这很干净。
- Java没有Groovy拥有的所有语法糖,因此我在函数接口中使用了java.lang.Runnable ,从而减少了创建闭包的语法,但缺点是必须在初始builder对象上具有一个句柄。
尽管没有Groovy建设者那么出色,但是向前迈出了一大步。 等不及Java 8。
翻译自: https://www.javacodegeeks.com/2014/06/builder-pattern-using-java-8.html