先是用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
的区别.