一句话: 数据与操作分离。
类只负责操作字典,来减少类中所包含的主要起POJO作用的成员。
我想了想,可能这样进行输出的时候,数据组织的规则可以避免和类的结构进行耦合,只不过由于完全通过字典进行数据组织,字典本身的结构是另一种没有被类的层级关系描述的规则
另外一篇 手记 提到了这几个类的关系。皆位于 org.apache.pdfbox.pdmodel
中。
感兴趣可以继续往下看。
几个典型类的数据组织方式
PDDocument
通过初始化其成员 COSDocument document
,
及该成员内部成员 COSDictionary trailer
。
以字典树(value 包含一个 字典) 形式组织数据。
public PDDocument() {
this(MemoryUsageSetting.setupMainMemoryOnly());
}
public PDDocument(MemoryUsageSetting memUsageSetting) {
// Scratch 草稿
ScratchFile scratchFile = null;
try {
scratchFile = new ScratchFile(memUsageSetting);
}
catch (IOException ioe) {
LOG.warn("Error initializing scratch file: " + ioe.getMessage() +
". Fall back to main memory usage only.");
try
{
scratchFile = new ScratchFile(MemoryUsageSetting.setupMainMemoryOnly());
}
catch (IOException ioe2) {
}
}
document = new COSDocument(scratchFile);
pdfSource = null;
// First we need a trailer
COSDictionary trailer = new COSDictionary();
document.setTrailer(trailer);
// Next we need the root dictionary.
COSDictionary rootDictionary = new COSDictionary();
trailer.setItem(COSName.ROOT, rootDictionary);
rootDictionary.setItem(COSName.