我在一个环境中工作,其中通过调用远程服务而不是使用数据库来执行大量日常脚本任务。
对于许多脚本编写任务,我经常使用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