abap方法调用方法调用中的参数

时间:2015-03-13 11:21:42

标签: oop methods parameters abap

我是abap(OO)的新手,但是之前在java中开发并写了一个类abap" cl_caretaker"它应该处理数据库表上的操作和它的本地副本(实习表)。

我想进行以下方法调用:

caretaker->show_table( caretaker->get_users( ) ) .

使用:

 caretaker = cl_caretaker=>get_instance( ). "singleton instance

METHODS:

"! get a list of all user which registrated for FCP
"!
"! @parameter rt_users    | users which are registrated for FCP
   get_users
      RETURNING value(rt_users) TYPE itty_users,


 "! shows the content of a table
 "!
 "! @parameter it_table             | the table we want to visualize
   show_table
      IMPORTING
        value(it_table) TYPE ANY TABLE.

如果我将调用分成两部分并将get_users的结果存储在tmp变量中,则可以正常工作。

DATA:
  gt_tmp_users TYPE caretaker->itty_users.

  gt_tmp_users = caretaker->get_users( ).
  caretaker->show_table( gt_tmp_users ).

所以我的问题是:

1)就是这样的电话:caretaker->show_table( caretaker->get_users( ) ).    可能,如果如何?

2)我还尝试创建一个通用变量,它存储所有类型的表。    因为我不想为每个表格创建,所以我使用tmp / help变量。    但我得到的信息是,只允许(德语:Formalparameter)方法定义的伪参数为泛型类型(例如,TYPE任何TABLE)。

这里有一些我已经尝试过的东西:

DATA:
*    tmpanytable TYPE TABLE OF any.
*    tmpAnyTable TYPE any.
    tmpanytable TYPE REF TO data.

 " needed to store a temporal table
 FIELD-SYMBOLS: <tmpanytable> TYPE ANY TABLE.

* ASSIGN caretaker->get_users( ) TO <tmpAnyTable>.
* <tmpAnyTable> = caretaker->get_users( ).
* caretaker->get_users( ).
*caretaker->show_table( <tmpAnyTable> ).
*caretaker->show_table( caretaker->get_users( ) ).

*CALL METHOD: caretaker->show_table( IMPORTING it_table = caretaker->get_users ).
*CALL METHOD: caretaker->show_table( it_table = caretaker->get_users( ) ).

*COMPUTE caretaker->show_table( it_table = caretaker->get_users( ) ).

*ASSIGN caretaker->get_users() ->* to <tmpAnyTable>.
*Caretaker->show_table( <tmpAnyTable> ).

*call METHOD caretaker->show_table
*                Exporting It_table = caretaker->get_users( ).

*  CREATE DATA tmpanytable TYPE STANDARD TABLE OF (dbtab)
*                            WITH NON-UNIQUE DEFAULT KEY.
*  ASSIGN tmpanytable->* TO <tmpanytable>.

*  CREATE DATA tmpanytable TYPE tabkind OF any Table .
*  ASSIGN tmpanytable->* TO <tmpanytable>.

*GET REFERENCE OF caretaker->get_users() INTO tmpAnyTable.
*caretaker->show_table( tmpAnyTable ) .

1 个答案:

答案 0 :(得分:1)

Method chaining是可能的,methods in operand positions也是可能的,但您至少需要SAP_ABA 702.

您可以使用泛型类型来传递表,而无需在运行时知道其类型。但是,您无法在不知道其类型的情况下创建表。将它与OO原则相比较,您可以处理对抽象超类的引用并在组件之间传递它们,但是您无法实例化抽象超类。 CREATE DATA语句需要“具体数据类型”才能使用,而不是“抽象超类型STANDARD TABLE”。这里的难点在于决定谁将了解类型并创建数据对象。

顺便说一句,你可能想看看内置的Object Services - 也许不需要再次重新发明数据库访问层轮。