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