ABAP中之枚举对象。ABAP中的枚举对象。

 

 

枚举对象是枚举类型的数码对象。枚举对象只能分包类型为枚举类型的枚举值。ABAP从本7.51初始支持其。

枚举对象是枚举类型的数对象。枚举对象只能分包类型也枚举类型的枚举值。ABAP从本7.51起支持其。

即是同等种普遍的模式。在ABAP 7.51之前,人们便用如下方式贯彻类似之功用:

立即是均等种植普遍的模式。在ABAP 7.51事先,人们平常用如下方式实现类似之功力:

CLASS cx_wrong_size DEFINITION INHERITING FROM cx_static_check.
 ENDCLASS.

 CLASS shirt DEFINITION.
   PUBLIC SECTION.
     TYPES tsize TYPE i.
     CONSTANTS:
       size_s  TYPE tsize VALUE 0,
       size_m  TYPE tsize VALUE 1,
       size_l  TYPE tsize VALUE 2,
       size_xl TYPE tsize VALUE 3.
     METHODS
       constructor IMPORTING size TYPE tsize
                   RAISING   cx_wrong_size.
     ...
   PRIVATE SECTION.
     DATA
       size TYPE tsize.
 ENDCLASS.

 CLASS shirt IMPLEMENTATION.
   METHOD constructor.
     IF size <> size_s AND
        size <> size_m AND
        size <> size_l AND
        size <> size_xl.
       RAISE EXCEPTION TYPE cx_wrong_size.
     ENDIF.
     me->size = COND #(
       WHEN size <> size_s AND
                    size <> size_m AND
                    size <> size_l AND
                    size <> size_xl THEN THROW cx_wrong_size( )
       ELSE size ).
   ENDMETHOD.
 ENDCLASS.
CLASS cx_wrong_size DEFINITION INHERITING FROM cx_static_check.
 ENDCLASS.

 CLASS shirt DEFINITION.
   PUBLIC SECTION.
     TYPES tsize TYPE i.
     CONSTANTS:
       size_s  TYPE tsize VALUE 0,
       size_m  TYPE tsize VALUE 1,
       size_l  TYPE tsize VALUE 2,
       size_xl TYPE tsize VALUE 3.
     METHODS
       constructor IMPORTING size TYPE tsize
                   RAISING   cx_wrong_size.
     ...
   PRIVATE SECTION.
     DATA
       size TYPE tsize.
 ENDCLASS.

 CLASS shirt IMPLEMENTATION.
   METHOD constructor.
     IF size <> size_s AND
        size <> size_m AND
        size <> size_l AND
        size <> size_xl.
       RAISE EXCEPTION TYPE cx_wrong_size.
     ENDIF.
     me->size = COND #(
       WHEN size <> size_s AND
                    size <> size_m AND
                    size <> size_l AND
                    size <> size_xl THEN THROW cx_wrong_size( )
       ELSE size ).
   ENDMETHOD.
 ENDCLASS.

此间,size属性只可以是shirt类中定义的常量中之值。其它值会导致大。用户创建shirt类时,需要如此做:

此间,size属性只堪是shirt类中定义之常量中的价值。其它值会导致大。用户创建shirt类时,需要如此做:

TRY.
    DATA(shirt) = NEW shirt( shirt=>size_xl ).
  CATCH cx_wrong_size.
    ...
ENDTRY.
TRY.
    DATA(shirt) = NEW shirt( shirt=>size_xl ).
  CATCH cx_wrong_size.
    ...
ENDTRY.

相出了为?为什么未叫运行时环境来吗您做值检查吧?有雷同栽叫做枚举和枚举类型的定义(可以以这种景象下以)。

见到出了吗?为什么未让运行时环境来为卿做值检查呢?有雷同栽名叫枚举和枚举类型的概念(可以在这种情况下使用)。

当7.51与重复强之版本里,ABAP也会见支撑枚举概念。如果应用枚举类型来更写点的事例的语:

每当7.51同重新胜似的本里,ABAP也会见支持枚举概念。如果使用枚举类型来还写点的例子的口舌:

CLASS shirt DEFINITION.
  PUBLIC SECTION.
    TYPES:
      BEGIN OF ENUM tsize,
        size_s,
        size_m,
        size_l,
        size_xl,
      END OF ENUM tsize.
    METHODS
      constructor IMPORTING size TYPE tsize.
    ...
  PRIVATE SECTION.
    DATA
      size TYPE tsize.
ENDCLASS.

CLASS shirt IMPLEMENTATION.
  METHOD constructor.
    me->size = size.
  ENDMETHOD.
ENDCLASS.
CLASS shirt DEFINITION.
  PUBLIC SECTION.
    TYPES:
      BEGIN OF ENUM tsize,
        size_s,
        size_m,
        size_l,
        size_xl,
      END OF ENUM tsize.
    METHODS
      constructor IMPORTING size TYPE tsize.
    ...
  PRIVATE SECTION.
    DATA
      size TYPE tsize.
ENDCLASS.

CLASS shirt IMPLEMENTATION.
  METHOD constructor.
    me->size = size.
  ENDMETHOD.
ENDCLASS.

TYPES语句的一个新变式:BEGIN OF ENUMEND OF
ENUM
,它可围绕起一个常量的聚合。常量的正式基本项目是i同时枚举值从0开始计数。

TYPES语句的一个初变式:BEGIN OF ENUMEND OF
ENUM
,它可绕起一个常量的汇。常量的科班基本型是i再者枚举值从0开始计数。

像上文那样使的语句:

譬如说上文那样以的语:

DATA(shirt) = NEW shirt( shirt=>size_xl ).
DATA(shirt) = NEW shirt( shirt=>size_xl ).

然而,使用了枚举对象后,你不再用处理非常了。如果您传递一个非法值的语句,会拿走语法错误!

而是,使用了枚举对象后,你不再用处理好了。如果您传递一个非法值的讲话,会获取语法错误!

DATA(shirt) = NEW shirt( 333 ).
DATA(shirt) = NEW shirt( 333 ).

图片 1

图片 2

 

 

枚举是种和常量的混合体。通过BEGIN OF ENUM enum – END OF ENUM
enum

你声明了一个得以于TYPE附加项后宣称的主导型enum。在它中,你得声明一个常量集,它们叫做枚举常量。这样便定义了具备enum品种的枚举对象所许的枚举值。在这里,TYPES实际就是跟CONSTANTS语一样。

枚举是项目和常量的混合体。通过BEGIN OF ENUM enum – END OF ENUM
enum

你声明了一个可以于TYPE附加项后宣称的为主型enum。在它们中间,你得声明一个常量集,它们叫做枚举常量。这样便定义了有enum种的枚举对象所许的枚举值。在此间,TYPES实在就是跟CONSTANTS话语一样。

ABAP运行时环境会检讨只有吃允许的枚举值可以叫与给枚举对象。

ABAP运行时环境会检讨只有吃允许的枚举值可以给与给枚举对象。

TYPES:
  BEGIN OF ENUM tsize,
    size_s,
    size_m,
    size_l,
    size_xl,
  END OF ENUM tsize.

DATA size TYPE tsize.
size = size_xl. "允许

DATA dobj LIKE size.
dobj = size. "允许

dobj = 333. "语法或运行时错误
TYPES:
  BEGIN OF ENUM tsize,
    size_s,
    size_m,
    size_l,
    size_xl,
  END OF ENUM tsize.

DATA size TYPE tsize.
size = size_xl. "允许

DATA dobj LIKE size.
dobj = size. "允许

dobj = 333. "语法或运行时错误

枚举对象只能赋值给有相同枚举类型的枚举对象。同样,枚举对象中的比呢只好以同一档次的枚举对象中发生。当然,枚举常量本身吗包含在内。

枚举对象只能赋值给拥有同样枚举类型的枚举对象。同样,枚举对象中的可比呢只好在同等档次的枚举对象中发生。当然,枚举常量本身吗包含在内。

平常,你或多或少呢未关心枚举对象的内容。枚举对象的语义由枚举常量来定义。然而,你为堪将枚举类型定义为i类型之外的其余基本类型,并且拥有别样枚举值(其中一个须要是初始值):

一般而言,你或多或少为无关心枚举对象的始末。枚举对象的语义由枚举常量来定义。然而,你啊堪拿枚举类型定义为i类型之外的别基本类型,并且有别样枚举值(其中一个要是初始值):

TYPES:
  basetype TYPE c LENGTH 2,
  BEGIN OF ENUM tsize BASE TYPE basetype,
    size_i  VALUE IS INITIAL,
    size_s  VALUE `S`,
    size_m  VALUE `M`,
    size_l  VALUE `L`,
    size_xl VALUE `XL`,
  END OF ENUM tsize.

DATA size TYPE tsize.
size = size_xl. "允许

DATA dobj LIKE size.
dobj = size."允许
TYPES:
  basetype TYPE c LENGTH 2,
  BEGIN OF ENUM tsize BASE TYPE basetype,
    size_i  VALUE IS INITIAL,
    size_s  VALUE `S`,
    size_m  VALUE `M`,
    size_l  VALUE `L`,
    size_xl VALUE `XL`,
  END OF ENUM tsize.

DATA size TYPE tsize.
size = size_xl. "允许

DATA dobj LIKE size.
dobj = size."允许

就使你可轻松地将现有“枚举值”转换为新点子的枚举值。运气好的话语,可以不需调其的使用。

随即如果您得轻松地管现有“枚举值”转换为新方式的枚举值。运气好之话语,可以免欲调动其的以。

一旦你于一个上下文中有过一个枚举类型,你可将逐条枚举值组织到组织里:

假若你当一个上下文中生出越一个枚举类型,你得以各个枚举值组织及组织里:

TYPES:
  BEGIN OF ENUM tsize STRUCTURE size,
    s,
    m,
    l,
    xl,
  END OF ENUM tsize STRUCTURE size.

DATA dobj TYPE tsize.
dobj = size-xl. "允许
TYPES:
  BEGIN OF ENUM tsize STRUCTURE size,
    s,
    m,
    l,
    xl,
  END OF ENUM tsize STRUCTURE size.

DATA dobj TYPE tsize.
dobj = size-xl. "允许

如上代码定义了一个枚举结构size。结构的零件是枚举类型的枚举常量。

上述代码定义了一个枚举结构size。结构的组件是枚举类型的枚举常量。

 

 

枚举对象的广大用处是较它与枚举常量以控制程序用切换到哪一个效果分:

枚举对象的大用处是于它和枚举常量以控制程序要切换到哪一个作用分:

TYPES:
  BEGIN OF ENUM tsize STRUCTURE size,
    s,
    m,
    l,
    xl,
  END OF ENUM tsize STRUCTURE size.

DATA dobj TYPE tsize.

...

CASE dobj.
  WHEN size-s.
    ...
  WHEN size-m.
    ...
  WHEN size-l.
    ...
  WHEN size-xl.
    ...
ENDCASE.
TYPES:
  BEGIN OF ENUM tsize STRUCTURE size,
    s,
    m,
    l,
    xl,
  END OF ENUM tsize STRUCTURE size.

DATA dobj TYPE tsize.

...

CASE dobj.
  WHEN size-s.
    ...
  WHEN size-m.
    ...
  WHEN size-l.
    ...
  WHEN size-xl.
    ...
ENDCASE.

 除此之外,还有一对得以行使之情景:

 除此之外,还有局部好以之景象:

君得拿枚举对象与给一个c种类或者string品类的文本。结果就是是概念了枚举值的枚举常量的名。

乃可拿枚举对象给予给一个c种或者string类的文书。结果就是是概念了枚举值的枚举常量的讳。

TYPES:
  BEGIN OF ENUM tsize,
    size_s,
    size_m,
    size_l,
    size_xl,
  END OF ENUM tsize.

DATA text TYPE string.
text = size_xl.
cl_demo_output=>display( text ). "结果是SIZE_XL
TYPES:
  BEGIN OF ENUM tsize,
    size_s,
    size_m,
    size_l,
    size_xl,
  END OF ENUM tsize.

DATA text TYPE string.
text = size_xl.
cl_demo_output=>display( text ). "结果是SIZE_XL

啊可以创作:

否得以编写:

DATA(text) = CONV string( size_xl ).
DATA(text) = CONV string( size_xl ).

可利用CONV操作符指定项目来访问当前值:

可以运用CONV操作符指定项目来访问当前值:

TYPES:
  BEGIN OF ENUM tsize,
    size_s,
    size_m,
    size_l,
    size_xl,
  END OF ENUM tsize.

DATA(value) = CONV i( size_xl ) .
cl_demo_output=>display( value ). "输出结果是3
TYPES:
  BEGIN OF ENUM tsize,
    size_s,
    size_m,
    size_l,
    size_xl,
  END OF ENUM tsize.

DATA(value) = CONV i( size_xl ) .
cl_demo_output=>display( value ). "输出结果是3

其他一样种方式是,可以以CONV用一个有效的枚举值转换为枚举对象(常规的赋值语句是心有余而力不足完成的):

任何一样栽艺术是,可以采用CONV以一个管用之枚举值转换为枚举对象(常规的赋值语句是无法就的):

TYPES:
  BEGIN OF ENUM tsize,
    size_s,
    size_m,
    size_l,
    size_xl,
  END OF ENUM tsize.

DATA(num) = 3.

TRY.
    DATA(dobj) = CONV tsize( num ) .
    cl_demo_output=>display( dobj ). "Output is SIZE_XL
  CATCH cx_sy_conversion_no_enum_value.
    ...
ENDTRY.
TYPES:
  BEGIN OF ENUM tsize,
    size_s,
    size_m,
    size_l,
    size_xl,
  END OF ENUM tsize.

DATA(num) = 3.

TRY.
    DATA(dobj) = CONV tsize( num ) .
    cl_demo_output=>display( dobj ). "Output is SIZE_XL
  CATCH cx_sy_conversion_no_enum_value.
    ...
ENDTRY.

RTTI吃呢差不多了一个对应的好像CL_ABAP_ENUMDESCR

RTTI着吗大半了一个应和的近乎CL_ABAP_ENUMDESCR

TYPES:
  BEGIN OF ENUM tsize,
    size_s,
    size_m,
    size_l,
    size_xl,
  END OF ENUM tsize.

DATA(size) = VALUE tsize( ).

DATA(enum_descr) = CAST cl_abap_enumdescr(
  cl_abap_typedescr=>describe_by_data( size ) ).

cl_demo_output=>new(
  )->write_data( enum_descr->kind            "E, for elementary
  )->write_data( enum_descr->type_kind       "k, new for enumerated type
  )->write_data( enum_descr->base_type_kind  "I, the base type
  )->write_data( enum_descr->members         "Table of constants and values
  )->display( ).
TYPES:
  BEGIN OF ENUM tsize,
    size_s,
    size_m,
    size_l,
    size_xl,
  END OF ENUM tsize.

DATA(size) = VALUE tsize( ).

DATA(enum_descr) = CAST cl_abap_enumdescr(
  cl_abap_typedescr=>describe_by_data( size ) ).

cl_demo_output=>new(
  )->write_data( enum_descr->kind            "E, for elementary
  )->write_data( enum_descr->type_kind       "k, new for enumerated type
  )->write_data( enum_descr->base_type_kind  "I, the base type
  )->write_data( enum_descr->members         "Table of constants and values
  )->display( ).

大抵就是是这些情节了。

差不多就是是这些情节了。

睡下于ABAP运行时来啊汝办事吧。要专注枚举类型只能以某些适合的运算位置被冒出,并且不得不分包预先规定的值。非法的枚举值永远不见面在枚举对象被起。

睡下深受ABAP运行时来啊汝办事吧。要专注枚举类型只能当某些适合的演算位置被出现,并且不得不分包预先规定的值。非法的枚举值永远不会见以枚举对象被冒出。

 

 

PS:原文的评价被有人涉嫌,枚举值和数码字典中的domain的固定值很像,为什么双方没有并轨关系?

PS:原文的评说中有人涉嫌,枚举值和多少字典中之domain的固定值很像,为什么双方没有并轨关系?

笔者的答疑是:这个特性实际上已于计划中了,很有梦想出现。具体情况要见到资源及预先级而一定。

笔者的应对是:这个特点实际上已经于统筹被了,很有期待出现。具体情况要顾资源同先期级而一定。

 

 

正文链接:http://www.cnblogs.com/hhelibeb/p/7976078.html

本文链接:http://www.cnblogs.com/hhelibeb/p/7976078.html

英文原稿:ABAP News for Release 7.51 –
Enumerations

英文原文:ABAP News for Release 7.51 –
Enumerations

 

 

相关文章

admin

网站地图xml地图