public interface Writable
Represents an object which is capable of writing itself to a text stream in a more efficient format than just creating a toString() representation of itself. This mechanism is particularly useful for templates and such like.
It is worth noting that writable implementations often override their toString() implementation as well to allow rendering the same result directly to a String; however this is not required.
Modifier and Type | Method and Description |
---|---|
java.io.Writer |
writeTo(java.io.Writer out)
Writes this object to the given writer.
|
java.io.Writer writeTo(java.io.Writer out) throws java.io.IOException
Writes this object to the given writer.
This is used to defer content creation until the point when it is streamed to the output destination. Oftentimes, content will be defined but not necessarily created (as is may be the case with a Closure definition.) In that case, the output is then 'deferred' to the point when it is serialized to the writer. This class may be used whenever an object should be responsible for creating its own textual representation, but creating the entire output as a single String would be inefficient (such as outputting a multi-gigabyte XML document.)
out
- the Writer to which this Writable should output its data.java.io.IOException
- if an error occurred while outputting data to the
writer