在创建ABAP程序时均需要指定其类型,程序类型将决定在该程序中可以包含哪些处理块,以及运行环境是如何处理该程序的。
ABAP程序分为两大类。一类是可以分配事务代码并通过事务代码直接运行的应用程序,这些代码用于完成一种系统功能,可以添加到最终用户的系统定制菜单中,比如显示并打印一个企业报表,或者是更新某些商业数据等;另一类不是为了实现特定的功能,只是为了系统开发中提供帮助,例如包含程序或功能模块程序。
1.应用程序类型
应用程序分为两种类型,分别是可执行程序和模块池程序:
·可执行程序(Executable program)常常用于创建通常意义上的报表,整个程序由REPORT关键字语句进行引导,可以包含自定义的屏幕,在ABAP编辑器中进行编辑,并可以直接在ABAP编辑器中执行也可以通过SUBMIT语句或者分配表事务代码来运行。
·模块池(Module pool)类型的程序在创建时由系统自动生成PROGRAM关键字语句进行引导,一般包含程序自身定义的屏幕和对话模块,在ABAP编辑器中进行编辑,且必须通过事务代码运行。
习惯上,ABAP程序开发人员往往将应用程序分为报表程序和对话程序(又称为动态程序、事务程序),可执行程序中可以处理报表事件,也可以加入屏幕和对话模块;而模块池程序一般只用于事务程序的设计。
2.其他程序类型
其他程序类型的程序是不能直接(或通过事务代码)执行的,但这些类型可以作为代码容器,可以为ABAP程序提供各种各样的模块化代码单元(如函数、子程序、宏等),如果一个可执行程序调用这些容器中的某一个模块,系统总是将载入整个程序,而不是所用的代码模块。这些程序类型包括:
·功能组(Function groups)由FUNCTION-POOL语句引导,包含一个或多个功能模块,也可以包含自己的屏幕,但一般不能直接运行。使用需要需要在普通程序中调用,此时整个功能组程序被整个加载至运行环境中。
·ABAP类库(Class pools)由CLASS-POOL语句引导,是系统ABAPA对象(ABAP Objects)的定义部分,不包括自身的屏幕,也不能直接执行,可以包含一个全局类和多个局域类。类库在程序使用全局类时被系统装载。
·ABAP接口库(Interface pools)由INTERFACE-POOL语句引导,与类库相似,用于定义ABAP对象的接口,可以被任意全局类和局域类实现,不能直接运行。
·子程序池(Subroutine pools)由PROGRAM语句引导,包含一个或多个子程序代码模块或类方法,这些过程不能直接运行,需要被普通程序调用。
·类型组(Type groups)由TYPE-POOL语句引导,在数据字典中定义,包含任何屏幕和处理块,用于定义全局数据类型,一旦在ABAP程序中使用TYPE-POOLS语句声明该类型组,就可以使用其中定义的类型。
·包含程序(Include programs),不需要任何语句进行引导,也不需要包含完整的处理模块(即无需独立编译,因为包含程序只是代码复用),在ABAP编辑器中进行编辑,可以直接插入到其他程序中,成为该程序的一部分。包含程序可以通过INCLUDE语句被多个程序引用,但与引用它的程序之间不存在参数接口。
参考书籍:SAP程序设计 黄佳