您不太可能遇到可以处理“传统”系统格式的框架。在大多数情况下,旧系统不使用标准格式,但框架需要它们。作为遗留 COBOL 系统和 Java/Groovy 转换的维护者,我经常遇到这种不匹配。“担心转换、填充、对齐、填充等”主要是您在处理遗留系统时所做的。当然,您可以将其中的一些封装到方便的助手中。但最有可能的是,您需要真正熟悉 java.util.Formatter。
例如,您可以使用装饰器模式来创建装饰器来进行转换。下面是一些 groovy(很容易转换成 Java):
class Entity{
String name = "name"; // length = 10; align left; fill with spaces
Integer id = 123; // length = 5; align left; fill with spaces
Integer serial = 321 // length = 5; align to right; fill with '0'
Date register = new Date();// length = 8; convert to yyyyMMdd
}
class EntityLegacyDecorator {
Entity d
EntityLegacyDecorator(Entity d) { this.d = d }
String asRecord() {
return String.format('%-10s%-5d%05d%tY%<tm%<td',
d.name,d.id,d.serial,d.register)
}
}
def e = new Entity(name: 'name', id: 123, serial: 321, register: new Date('2011/05/06'))
assert new EntityLegacyDecorator(e).asRecord() == 'name 123 0032120110506'
如果您没有太多这些并且对象不是太复杂,这是可行的。但是很快格式字符串就变得无法忍受了。然后你可能想要 Date 的装饰器,比如:
class DateYMD {
Date d
DateYMD(d) { this.d = d }
String toString() { return d.format('yyyyMMdd') }
}
所以你可以用 %s 格式化:
String asRecord() {
return String.format('%-10s%-5d%05d%s',
d.name,d.id,d.serial,new DateYMD(d.register))
}
但是对于大量的 bean 属性,字符串仍然太粗略,所以你想要一些能够理解列和长度的东西,看起来就像你收到的 COBOL 规范,所以你会写这样的东西:
class RecordBuilder {
final StringBuilder record
RecordBuilder(recordSize) {
record = new StringBuilder(recordSize)
record.setLength(recordSize)
}
def setField(pos,length,String s) {
record.replace(pos - 1, pos + length, s.padRight(length))
}
def setField(pos,length,Date d) {
setField(pos,length, new DateYMD(d).toString())
}
def setField(pos,length, Integer i, boolean padded) {
if (padded)
setField(pos,length, String.format("%0" + length + "d",i))
else
setField(pos,length, String.format("%-" + length + "d",i))
}
String toString() { record.toString() }
}
class EntityLegacyDecorator {
Entity d
EntityLegacyDecorator(Entity d) { this.d = d }
String asRecord() {
RecordBuilder record = new RecordBuilder(28)
record.setField(1,10,d.name)
record.setField(11,5,d.id,false)
record.setField(16,5,d.serial,true)
record.setField(21,8,d.register)
return record.toString()
}
}
在您编写了足够多的 setField() 方法来处理遗留系统之后,您将简要考虑将其作为“框架”发布在 GitHub 上,这样下一个可怜的 sap 就不必再次使用它了。但随后您将考虑您所见过的所有荒谬方式 COBOL 存储“日期”(MMDDYY、YYMMDD、YYDDD、YYYYDDD)和数字(假定为十进制、显式十进制、符号作为尾随分隔符或符号作为前导浮动字符)。然后你就会意识到为什么没有人为此制作一个好的框架,并且偶尔将你的生产代码的一部分发布到 SO 作为示例......;)