我对番石榴和它的风格有点陌生。我肯定在挖掘它,但我一直绊倒的一件事是链式方法的顺序。我似乎遇到这个问题最多的地方是使用 Compound Ordering
s 时。我必须不断问自己以下问题:
- 去哪儿
natural
? nullFirst
(或最后)去哪儿了?- 哪个
nullsFirst
做什么?(在下面的示例中,一个用于主机,一个用于姓氏,一个用于名字?)
这是我刚刚研究的一个例子。它看起来很麻烦,我只是不确定我是否把它们放在一起正确。我有一些 JUnit 来测试它,看起来还不错,但总是有那些古怪的边界情况。
Ordering<Host> lastNameThenFirstNameOrdering = Ordering.natural().nullsFirst().onResultOf(new Function<Host, String>() {
public String apply(Host host) {
return host.getLastName();
}}).compound(Ordering.natural().nullsFirst().onResultOf(new Function<Host, String>() {
public String apply(Host host) {
return host.getFirstName();
}})).nullsFirst();
至于一个实际的问题:这些事情如何执行是否有明确的规则?这似乎是从后到先的,但我很难说清楚。
编辑:只是想指出我试图替换的大而丑陋的代码:
Ordering<Host> ordering2 = new Ordering<Host>() {
public int compare(Host host1, Host host2) {
if (host1 == null || host2 == null) {
return host1 == host2 ? 0 : ((host1 == null) ? -1 : 1);
}
if(host1.getLastName() != null || host2.getLastName() != null){
if (host1.getLastName() == null) {
return -1;
} else if (host2.getLastName() == null) {
return 1;
}
if (host1.getLastName().compareTo(host2.getLastName()) != 0) {
return host1.getLastName().compareTo(host2.getLastName());
}
}
if (host1.getFirstName() == null) {
return -1;
} else if (host2.getFirstName() == null) {
return 1;
}
return host1.getFirstName().compareTo(host2.getFirstName());
}};