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