我是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 ) .
答案 0 :(得分:1)
Method chaining是可能的,methods in operand positions也是可能的,但您至少需要SAP_ABA 702.
您可以使用泛型类型来传递表,而无需在运行时知道其类型。但是,您无法在不知道其类型的情况下创建表。将它与OO原则相比较,您可以处理对抽象超类的引用并在组件之间传递它们,但是您无法实例化抽象超类。
CREATE DATA
语句需要“具体数据类型”才能使用,而不是“抽象超类型STANDARD TABLE
”。这里的难点在于决定谁将了解类型并创建数据对象。