先是用TYPES 关键字定义一个行(row) 的类型. 如下:
TYPES: BEGIN OF line,
field1 TYPE i,
field2 TYPE i,
END OF line.
这里的line, 就相当于一个自定义 的类型 , 表示一行(row) 的字段(field).
这里一行有两个字段field1 和field2.
然后是声明一个work area:
DATA wa TYPE line.
运用面向对象的概念理解就是,
line 是一个class, 而wa 是一个object.
接着是声明一个每一行的类型是line 的internal table:
DATA itab TYPE line OCCURS 0.
我在暂时把OCCURS 作为了区别工作区和内表的标志 .
OCCURS 应该有更深层次的意义, 但我目前只能领悟至此...
当我们用以上这个方法来声明一个iternal table 时, 可以选择是否有无header line.
上面这句就是没有header line 的. 改成如下就有了:
DATA itab TYPE line OCCURS 0 WITH HEADER LINE.
有无header line 的区别就是,header line 可以当作一个work area 来使用 .
有一下两种方式操作itab:
1).
wa-field1 = 1.
wa-field2 = 2.
APPEND wa TO itab.
2).
itab-field1 = 1.
itab-field2 = 2.
APPEND itab.
这里wa 就是上面那个已经定义的work area.
有header line 的时候, 这两种都可以.
无header line 的时候, 只能用第1 种.
第2 种里,itab 的意义是一个header line, 而不是内表.
因为"DATA itab TYPE line OCCURS 0 WITH HEADER LINE." 这样的声明,
已经隐式声明了一个与内表同名的header line.
所以OCCURS 用来声明内表可能造成二义性(ambiguous).
于是,OCCURS 被认为是old 的东西, 采用一下方式声明一个内表比较好:
DATA itab TYPE STANDARD TABLE OF line.
还有一种声明内表的方法:
DATA: BEGIN OF itab OCCURS 0,
field1 TYPE i,
field2 TYPE i,
END OF itab.
这样的itab 就自动有了一个同名的header line.
好像不会有 WITHOUT HEADER LINE 或者 NOT WITH HEADER LINE 这样的用法...
如果没有OCCURS 0, 比如这样:
DATA: BEGIN OF itab,
field1 TYPE i,
field2 TYPE i,
END OF itab.
那么这个itab 就不是内表咯, 只是一个structure, 可以作为itab 的work area.
写到这里发现, 归根到底就是TYPES 和DATA 这两个关键字的区别嘛.
还有有无OCCURS 的区别