06面向对象编程,A1.1-员工管理(本地类)

2018-02-25  本文已影响0人  真言真语SAP

本实践通过程序编辑器(SE38)即可完成,编写的代码将有如下几部分组成,按开发人员风格不同,其组成部分并非强制一致。

No 部分 说明
1 程序声明 声明本程序执行后是否包含标准标题,数据输出宽度和每页的行数量为多少
2 对象定义 通过定义变量或常量或要使用的表结构等,以在程序执行过程中计算和存储临时值
3 类的定义 定义一个类,类中包含公共区域和私有区域
4 类的方法 从表中获得员工数据并存储到变量以待后续输出
5 数据输出 创建对象实例并调用方法,并按需求进行数据的输出

1、程序声明

程序声明部分代码如下:

REPORT zu0601_employee_method.

REPORT 程序名称,是对程序的定义,表明此程序代码不是FUNCTION MODULE(功能函数),不是CLASS(类),而是可以执行的可以输出数据的此程序;这是对程序最基本的声明,且必须存在的部分。

2、对象定义

对象定义部分代码如下:

******对象定义*****
CLASS local_employee DEFINITION DEFERRED.       "未定义本地类
DATA: cl_ref        TYPE REF TO local_employee,
      out_emp_id    TYPE ztemployee-employeeid,
      out_emp_sex   TYPE ztemployee-sex,
      out_emp_newid TYPE ztemployee-employeeid,
      writestr(20)  TYPE c.

PARAMETERS p_emp_id TYPE ztemployee-employeeid.

如上代码,首先通过预定义一个本地类“local_employee”,此类将在后续步骤中进行定义和实现;然后参考此类定义了一个cl_ref的对象,以在程序执行时创建员工对象实例;同时定义了变量: out_emp_id(员工ID)、 out_emp_sex(性别)、out_emp_newid(最新员工ID)、writestr(性别),以在程序执行时存储获得的员工信息以待输出;

最后通过PARAMETERS定义了一个初始输入框以输入员工ID。

3、类的定义

在对象预定义local_employee类后,还需要进行类的详细定义,包括类所包含的方法、属性,以及各方法、属性的访问控制级别:公开(PUBLIC)、保护(PROTECTED)、私有(PRIVATE)。详细代码如下。

CLASS local_employee DEFINITION.
  PUBLIC SECTION.                        "公有成员
    METHODS get_emp_lastid               "获得最后一个员工ID
      RETURNING
        VALUE(re_emp_id) TYPE ztemployee-employeeid.
    METHODS get_emp_byid                  "指定员工ID
      IMPORTING
        VALUE(im_emp_id) TYPE ztemployee-employeeid.
    METHODS get_emp_sex                   "获得员工的性别
      RETURNING
                 VALUE(re_emp_sex) TYPE ztemployee-sex
      EXCEPTIONS no_data.
    METHODS show_emp_maxid.                   "输出最后的员工ID
    METHODS set_emp_newid                  "设置新的员工ID
      RETURNING
        VALUE(re_newemp_id) TYPE ztemployee-employeeid.

  PRIVATE SECTION.                              "私有成员
    DATA:emp_maxid TYPE ztemployee-employeeid,  "员工类的最大员工id值
         emp_id    TYPE ztemployee-employeeid.  "员工类的员工id
ENDCLASS.

通过如上代码,定义了类local_employee有4种方法:get_emp_lastid(获得最后一个员工ID)、get_emp_byid(根据输入值获得员工)、get_emp_sex(获得员工性别)、show_emp_maxid(输出最后员工ID)、set_emp_newid(设置新的ID),这些方法都是在PUBLIC SECTION中,表明对外公开;另外定义了2个属性emp_maxid(员工的最大ID)、emp_id(员工对象的ID),这2个属性都是在PRIVATE SECTION中,表明只能在对象的内部访问。

4、类方法的实现

在《类的定义》中,只是说明类包含了哪些方法哪些属性,但并没有说明方法的具体实现、属性的赋值等,在本部分则进行这些方法、属性赋值的实现。

CLASS local_employee IMPLEMENTATION.
  METHOD get_emp_lastid.
    SELECT MAX( employeeid ) FROM ztemployee INTO emp_maxid. "从员工表中获得最大员工ID值
    emp_id = emp_maxid.                                              "赋值给员工类中的emp_id属性
    re_emp_id = emp_id.                                              "赋值给方法的输出参数re_emp_id
  ENDMETHOD.

  METHOD get_emp_byid.
    emp_id = im_emp_id.                                        "输入值直接赋值给员工类的emp_id属性
  ENDMETHOD.

  METHOD get_emp_sex.
    SELECT SINGLE sex  FROM ztemployee INTO re_emp_sex  "根据员工类的emp_id属性值从表获得性别
WHERE employeeid = emp_id.
    IF re_emp_sex IS INITIAL.
      RAISE no_data.
    ENDIF.
  ENDMETHOD.

  METHOD show_emp_maxid.
    WRITE:/5 '最后员工ID:' ,20 emp_maxid.                  "输出员工类中的emp_maxid属性值
  ENDMETHOD.

  METHOD set_emp_newid.
    DATA new_id(4) TYPE n.
    new_id = emp_maxid+1(4).                                 "根据员工类中的emp_maxid属性值得到新的ID
    new_id = new_id + 1.
    re_newemp_id = 'E' && new_id.
  ENDMETHOD.
ENDCLASS.

代码说明如下:
get_emp_lastid: 通过OPEN SQL从员工表中获得最大ID号;
get_emp_byid: 获取选择界面输入的员工ID号;
get_emp_sex: 根据员工ID从员工表中获得性别,并判断性别是否为空,空则抛出异常;
show_emp_maxid: 输出员工类中的emp_maxid值;
set_emp_newid: 根据最大员工ID号,计算出最新ID号。

5、数据输出

在前面各个部分完成后,则可在START-OF-SELECTION事件中,通过创建对象实例并调用方法,获得和输出数据。

*&----------------------------------------------------------------------*
*& START-OF-SELECTION
*&----------------------------------------------------------------------*
START-OF-SELECTION.
  CREATE OBJECT cl_ref. "创建对象
  CALL METHOD cl_ref->get_emp_byid               "调用方法的方式1
    EXPORTING
      im_emp_id = p_emp_id.
  CALL METHOD cl_ref->get_emp_sex
    RECEIVING
      re_emp_sex = out_emp_sex
    EXCEPTIONS
      no_data    = 1.
**  cl_ref->get_emp_byid( p_emp_id ).             "调用方法的方式2
**  out_emp_sex = cl_ref->get_emp_sex( ).
  IF sy-subrc <> 0.
    writestr = '没有获得性别'.
  ELSE.
    writestr = out_emp_sex.
  ENDIF.
  WRITE:/5 '输入员工ID', 20 p_emp_id,
        /5 '输入员工性别:',20 writestr.
  SKIP.

  out_emp_id = cl_ref->get_emp_lastid( ).
  out_emp_sex = cl_ref->get_emp_sex( ).
  WRITE:/5 '最后员工ID', 20 out_emp_id,
        /5 '最后员工性别:',20 out_emp_sex.
  SKIP.

  cl_ref->show_emp_maxid( ).
  out_emp_newid = cl_ref->set_emp_newid( ).
  WRITE:/5 '最新员工ID:',20 out_emp_newid.

  CLEAR cl_ref.

在如上代码中:
首先通过CREATE创建对象的实例;
然后再通过CALL METHOD语句调用方法获得相应数据或执行相应语句,并根据获得的数据进行处理;
最后通过语句CLEAR清理对象内容。

上一篇 下一篇

猜你喜欢

热点阅读