Exploit DiscoveryNode immutability in toString

DiscoveryNode is immutable yet we rebuild DiscoveryNode#toString on
every invocation. Most importantly, this just leads to unnecessary
allocations. This is most germane to ZenDiscovery and the processing of
cluster states where DiscoveryNode#toString is invoked when submitting
update tasks and processing cluster state updates.

Closes #17543
This commit is contained in:
Jason Tedor 2016-04-05 12:13:18 -04:00
parent 8430b379d8
commit e76038e076
1 changed files with 21 additions and 16 deletions

View File

@ -312,25 +312,30 @@ public class DiscoveryNode implements Writeable<DiscoveryNode>, ToXContent {
return nodeId.hashCode(); return nodeId.hashCode();
} }
private String toString;
@Override @Override
public String toString() { public String toString() {
StringBuilder sb = new StringBuilder(); if (toString == null) {
if (nodeName.length() > 0) { StringBuilder sb = new StringBuilder();
sb.append('{').append(nodeName).append('}'); if (nodeName.length() > 0) {
sb.append('{').append(nodeName).append('}');
}
if (nodeId != null) {
sb.append('{').append(nodeId).append('}');
}
if (Strings.hasLength(hostName)) {
sb.append('{').append(hostName).append('}');
}
if (address != null) {
sb.append('{').append(address).append('}');
}
if (!attributes.isEmpty()) {
sb.append(attributes);
}
toString = sb.toString();
} }
if (nodeId != null) { return toString;
sb.append('{').append(nodeId).append('}');
}
if (Strings.hasLength(hostName)) {
sb.append('{').append(hostName).append('}');
}
if (address != null) {
sb.append('{').append(address).append('}');
}
if (!attributes.isEmpty()) {
sb.append(attributes);
}
return sb.toString();
} }
@Override @Override