Java COBOL comp 和 comp-3 字段的映射

Java mapping for COBOL comp and comp-3 fields

我正在从我的 java 应用程序调用使用 COBOL 创建的 DB2 存储过程。

输入宏(类型varchar):

01 SP1-INPUTS.
    05 FIELD-1      PIC X(03).
    05 FIELD-2      PIC S9(09) COMP.
    05 FIELD-3      PIC S9(15)V9(02) COMP-3.
    05 FIELD-3X     REDEFINES  FIELD-3 PIC X(09)

为了测试存储过程,我只知道 FIELD-1 的值。对于其他字段,要填充填充部分,我应该放多少个零?请参阅我编写的代码,并在传递虚拟值时感到困惑。

String field1="abc";
String field2="000000000"; // 9 zeroes, correct?
String field3="00...0" // should I give 18 zeroes or 9 zeroes?

输入宏一共有多少字符?

COBOL 没有字符串,它有没有终止符的固定长度字段。

所以对于 FIELD-1,你有三个 "characters"。 X 的图片可以允许 256 个可能的位值中的任何一个,但通常包含人类可读的值。

FIELD-2 是二进制字段。您可以将其视为一个四字节整数。

但是,它在那里定义的方式,COMP,带有 S,它的最大值为 999,999,999 正数,最小值为 999,999,999 负数。

如果它被定义为 COMP-5,它可以包含这四个字节中所有位的完整范围。请注意,编译器选项 TRUNC(BIN) 无论如何都会将 COMP 的行为修改为 COMP-5,因此您需要向大型机端检查 TRUNC 使用的编译选项是什么(其他值是 STD 和 OPT)。

在 IBM 大型机上,本机二进制字段是 Big Endian。在您的本地机器上,本机二进制值将是 Little Endian。例如,值 16906090 将存储为 X'01020304'。

FIELD-3 是压缩十进制。它有 9 个字节长,但每个字节包含两位十进制数字,除了低位(最右边)字节包含一位数字后跟一个符号说明符(图片使用 S,所以符号应该是 C 表示正数和D 代表负数,base-16)。有一个隐含的小数点(V)和两位小数。

FIELD-3X 是另一个 X 字段。它可以再次在每个字节中包含任何位模式。您需要知道该字段的预期用途是什么(与其他字段一样,名称中甚至没有丝毫线索,这是一种糟糕的做事方式)。

设计有误。将二进制和压缩十进制字段从大型机发送到其他地方是完全疯狂的,或者 反之亦然。如果 所有 字段定义为 X 或 9 而没有 COMP 或 COMP-3 的 USAGE(隐含),那么你会很轻松。

最终定义中缺少必需的 full-stop/period,但这很可能是通心粉。

   01  SP1J-INPUTS. 
       05  a-meaningful-name               PIC X(03). 
       05  another-meaningful-name         PIC S9(09) 
                                            SIGN LEADING SEPARATE.
       05  a-third-meaningful-name         PIC +9(15).9(02). 
       05  yet-annother-meaningful-name 
           REDEFINES a-third-meaningful-name 
                                           PIC X(19). 

这显示了两种处理符号的方法,一种是使用 SIGN 子句,另一种是使用经过数字编辑的定义。数字编辑定义中的 . 是一个实际的小数点,而不是隐含的小数点,带有 V.

所有数据现在都是"text"或"character"数据,应该很容易处理。 EBCDIC(IBM 大型机编码)到 ASCII(可能是您的本地机器编码)很容易,并且可以在数据级别而不是字段级别完成。

对于您的来回交流,以上内容对您来说会容易得多,更不容易出错并且更容易审核。在内部,COBOL 程序可以轻松地转换 to/from 那些供其内部使用。

如果您不让他们将您的界面更改为 "character",那么您将需要进行各种额外的编码和测试,但没有任何好处。

ABC 123456789(负)和 123456789012345.67(正)布局示例为

ABC-123456789+123456789012345.67

请注意,除了没有字段分隔符外,也没有 data/record 分隔符。没有 "null"s.

有一个替代实际小数点的方法,即提供一个比例因子。此外,您可以 "hard-code" 在您的程序中进行缩放。

我假设以上数据对您来说很容易接受和创建。请尝试更改您的界面。如果他们拒绝,请与您的老板一起记录额外代码的影响,并且额外代码只是为了能够 "understand" 数据,甚至在您开始考虑使用它之前。这很愚蠢。

要为您创建简单格式的数据,COBOL 程序需要这样做:

MOVE FIELD-1                  TO a-meaningful-name 
MOVE FIELD-2                  TO another-meaningful-name
MOVE FIELD-3                  TO a-third-meaningful-name

要从您那里接收易格式数据,COBOL 程序需要这样做:

MOVE a-meaningful-name        TO FIELD-1 
MOVE another-meaningful-name  TO FIELD-2     
MOVE a-third-meaningful-name  TO FIELD-3

如果 REDEFINES 有一个目的,它需要第四个字段的特定代码,但这对我来说很难猜测,但一旦知道实际需要,编码就不难了。

没有什么繁重的,而且比您必须编写的代码简单得多。