SAP入门技术分享四:模块化程序-创新互联

模块化程序
  • 1.子程序概要
  • 2.子程序定义
  • 3.子程序参数
    • (1)传递参数的方法
    • (2)定义参数类型
    • (3)参数与结构体
    • (4)参数与内表
    • 4.调用子程序
    • (1)调用程序内部子程序
    • (2)调用程序外部子程序
    • (3)动态调用子程序
  • 5.结束子程序
  • 6.临时动态子程序
  • 7.PERFORM ON COMMIT
    • (1)PERFORM ON COMMIT
    • (2)PERFORM ON ROLLBACK
    • (3)局部Macro(宏)
    • (4)全局Macro(宏)
    • 8.函数概要
  • 9.创建函数组
  • 10.函数
    • (1)属性
    • (2)传入参数
    • (3)传出参数
    • (4)传入/传出参数
    • (5)表参数
    • (6)例外处理
  • 11.RFC

创新互联专注于开江企业网站建设,响应式网站开发,商城网站建设。开江网站建设公司,为开江等地区提供建站服务。全流程按需设计,专业设计,全程项目跟踪,创新互联专业和态度为您提供的服务1.子程序概要

  定义:把有具体功能的代码集合在一起的程序块,可以重复使用。

2.子程序定义

  FORM ENDFORM定义;
  PERFORM调用;
  命名:动词+宾语。

3.子程序参数

  实参:调用子程序时使用;
  虚参:在子程序中使用;
  分类:USING、CHANGING。
  例子:
在这里插入图片描述

(1)传递参数的方法

在这里插入图片描述
  Call by Value:使用USING关键字传递时与VALUE语句一起搭配使用。
在这里插入图片描述
  注:实参和虚参占有自己单独的内存空间,改变虚参的值不会影响实参。
  Call by Reference:使用CHANGING关键字传递参数的情况。
在这里插入图片描述
注:虚参没有自己的内存空间,只是在调用子程序时占用实参的地址,改变虚参的值会影响实参。
区别:若在子例程FORM语句中不使用VALUE语句,则USING与CHANGING语句功能是相同的,将USING代表传递数据,CHANGING代表传递数据后变更其值。
  为了避免发生实参值在调用子程序后不被修改的情况,当使用USING时要与VALUE语句搭配使用,无法修改实参值。
  Call by Value and Result:
在这里插入图片描述
  当CHANGING语句和VALUE语句搭配使用时,会修改实参值。

(2)定义参数类型

  子例程中的虚参可以利用TYPE与LIKE语句定义所有的ABAP数据类型。若不明确指定类型,则被定义为Generic类型,继承实参的技术属性。
  虚参的定义方法有如下三种:
在这里插入图片描述

(3)参数与结构体

  当结构体当作参数使用时,不仅能使用TYPE、LIKE语句定义,还可以使用STRUCTURE语句定义结构体类型。
在这里插入图片描述

(4)参数与内表

A.USING、CHANGING语句
  当子程序参数为内表时也可以使用关键字USING、CHANGING。
在这里插入图片描述
  若用TYPE ANY TABLE指定了参数,则在子例程中要改成动态形式。
  使用内表指定参数也有下列三种方法:
在这里插入图片描述
B.TABLES语句
  使用TABLES语句定义虚参,不支持相同的物理内存地址。
在这里插入图片描述

4.调用子程序

  调用子程序的方法有Internal、External两种。通过PERFORM语句既可以调用内部子程序,还可以调用其他程序的子程序。
在这里插入图片描述

(1)调用程序内部子程序

  只要用PERFORM语句指定FORM名就可以实现。

(2)调用程序外部子程序

  调用外部程序的子程序时首先要利用IF FOUND语句检查是否存在该子程序。
在这里插入图片描述

(3)动态调用子程序

  调用外部程序的子程序时可以动态地指定名字。

5.结束子程序

  用ENDFORM结束子程序,还可以利用EXIT、CHECK语句强制在执行过程中结束此子程序。
  遇到EXIT语句:直接跳出子程序。
  遇到CHECK语句:判断值为假时跳出子程序。
  例子:
在这里插入图片描述

6.临时动态子程序

  语法:
  
  可以用上面的语法创建子程序池,将子程序池的代码插入到内表中。
  常用:动态定义内表。
  例子:
在这里插入图片描述

7.PERFORM ON COMMIT

  如果调用子程序时使用ON COMMIT/ROLLBACK选项,则每当遇到COMMIT WORK或者ROLLBACK WORK语句时才执行此FORM。

(1)PERFORM ON COMMIT

  遇到COMMIT WORK时调用子程序。

(2)PERFORM ON ROLLBACK

  遇到COMMIT ROLLBACK时调用子程序。
  例子:
在这里插入图片描述

(3)局部Macro(宏)

在这里插入图片描述
  例子:
在这里插入图片描述

(4)全局Macro(宏)

  全局宏Macro在数据库表TRMAC中进行维护,经常使用的全局Macro中包含指定断点时用的BREAK语句。
在这里插入图片描述
  注:如果双击ABAP命令,出现下列消息,就意味着是全局Macro。
在这里插入图片描述

8.函数概要

  定义:函数是储存在中央库中的特殊全局子程序。
  内容:传入参数、传出参数、传入/传出参数表、例外处理。
  与子例程的区别:
在这里插入图片描述
  函数组:通过函数编辑器创建函数和函数组,则系统会自动生成主程序及共享程序。
  主程序名字自动由SAPL+函数组名组成,且函数组的INCLUDE主程序如下:
在这里插入图片描述

9.创建函数组

在这里插入图片描述

10.函数 (1)属性

在这里插入图片描述
在这里插入图片描述

(2)传入参数

在这里插入图片描述
在这里插入图片描述

(3)传出参数

在这里插入图片描述
在这里插入图片描述

(4)传入/传出参数

  与调用此函数的ABAP程序可以同时传入/传出参数。
在这里插入图片描述

(5)表参数

  表参数可以传递复数值。
在这里插入图片描述
在这里插入图片描述

(6)例外处理

在这里插入图片描述
在这里插入图片描述

11.RFC

  (1)目的:充当源系统和R/3系统的数据接口。
  (2)设置:创建函数时设置成远程启用的模块。
在这里插入图片描述

你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧


名称栏目:SAP入门技术分享四:模块化程序-创新互联
本文来源:http://abwzjs.com/article/jsied.html