本篇内容主要讲解“ABAP关键字IS BOUND, IS NOT INITIAL和IS ASSIGNED怎么使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“ABAP关键字IS BOUND, IS NOT INITIAL和IS ASSIGNED怎么使用”吧!
目前成都创新互联公司已为成百上千的企业提供了网站建设、域名、网络空间、网站托管、企业网站设计、洮北网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。
ABAP里的IS BOUND, IS NOT INITIAL和IS ASSIGNED这组关键字,如果平时不留心,很容易理解地似是而非。今天我们就来说一说它们的区别。
先把SAP帮助文档抄过来:
IS BOUND
It checks whether a reference variable contains a valid reference. A data reference variable that contains a stack reference, on the other hand, can become invalid even if the reference data object is removed from the stack.
IS INITIAL
checks whether the operand operand is initial. The expression is true, if the operand contains its type-friendly initial value.
IS ASSIGNED
checks whether a memory area is assigned to a field symbol. The expression is true if the field symbol points to a memory area.
简单翻译成中文:
IS BOUND:用于检查一个引用变量是否指向了一个有效的引用。帮助文档特意提到,如果一个引用指向的是一个栈上申请的变量,那么这个变量会随栈的销毁而被销毁,因此指向其的引用不再有效。
IS INITIAL: 用于检查一个变量的值是否为其数据类型对应的初始值。
比如我定义一个引用变量但不对其赋值,则IS INITIAL判断一定为abap_true.
IS ASSIGNED: 对于检测的field symbol,该关键字判断该field symbol是否分配有内存区域。
这三个关键字交织在一起,就形成了一些有趣的排列组合。
比如,是否存在NOT INITIAL, 但同时也NOT BOUND的变量?是否存在同时满足IS INITIAL, NOT BOUND和IS ASSIGNED的field symbol? 下面我们用一个简单的ABAP报表来研究这些排列组合。
完整的测试代码:
同时满足NOT INITIAL和NOT BOUND的引用变量
下图main方法里,第15行在栈上定义了一个整型变量number,将其引用赋给类的成员变量dref. 待main方法执行之后,number所生存的栈帧被销毁,因此dref指向的引用不再有效,调试器里显示为:FREED STACK.
现在dref并不是未指向任何引用,而是指向一个无效的引用,因此dref同时满足IS NOT INITIAL和IS NOT BOUND.
IS ASSIGNED
一个field symbol定义之后,如果不为其分配内存区域,则IS ASSIGNED返回abap_false.
下面的代码,如果注释掉第27行的IF条件:
运行时会抛出GETWA_NOT_ASSIGNED错误:Field symbol has not yet been assigned.
也就是说,无论是读取field symbol具体的内容,还是检测其内容是否为初始值,为了避免GETWA_NOT_ASSIGNED错误,我们必须在IS INITIAL判断之前,使用IS ASSIGNED判断field symbol是否被分配了内存区域。
是否存在一个NOT BOUND, IS INITIAL但是却IS ASSIGNED的field symbol?
答案是肯定的。
上面代码第37行定义的名为
该报表打印输出如下:
第40行代码通过ASSIGN分配给
到此,相信大家对“ABAP关键字IS BOUND, IS NOT INITIAL和IS ASSIGNED怎么使用”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
本文名称:ABAP关键字ISBOUND,ISNOTINITIAL和ISASSIGNED怎么使用
URL分享:http://scpingwu.com/article/poseic.html