ABAP正则表达式 vs SPLIT INTO

简介:

需求: 把如下通过"/"连接起来的三个字符串分别解析出来。

传统的做法见下图第98行的function module SKWF_UTIL_IO_FIND_BY_KEY:

这个function module的作用就是解析用两个/分隔开的document type: L, document class: CRM_L_ORD和document guid。

这个function module采用传统的做法,把三个key拆分并存储到一个内标里,然后READ TABLE INDEX 1,2,3的方式分别取出每个key。用了42行代码。

如果用正则表达式,只需1行代码:

而且后者比前者快3~6倍:因为FIND REGEX是在ABAP Kernel用C++实现的,比在ABAP端做要高效。参考如下的性能测试比较结果(单位:微秒)。

要获取更多Jerry的原创技术文章,请关注公众号"汪子熙"或者扫描下面二维码:

相关文章
使用 ABAP 正则表达式提高字符串解析的执行效率
使用 ABAP 正则表达式提高字符串解析的执行效率
|
SQL 数据库
SAP ABAP——OPEN SQL(一)【INTO语句】
本文主要介绍SAP ABAP中OPEN SQL的INTO语句
596 0
SAP ABAP——OPEN SQL(一)【INTO语句】
字符串匹配 正则表达式函数之match、test、exec、search、split、replace使用详解
字符串匹配 正则表达式函数之match、test、exec、search、split、replace使用详解
126 0
|
XML SQL Unix
现代 ABAP 编程语言中的正则表达式
现代 ABAP 编程语言中的正则表达式
308 0
现代 ABAP 编程语言中的正则表达式
|
存储 测试技术 C++
ABAP正则表达式 vs SPLIT INTO
需求: 把如下通过"/"连接起来的三个字符串分别解析出来。
121 0
ABAP正则表达式 vs SPLIT INTO
ABAP传值和传引用的性能比较 - pass by value VS pass by reference
When I was doing MyTask offline performance optimization, I hesitated about whether to use pass by value or pass by reference. Pass by value pattern using RETURNING keyword:
167 0
ABAP传值和传引用的性能比较 - pass by value VS pass by reference
ABAP传值和传引用的性能比较 - pass by value VS pass by reference
When I was doing MyTask offline performance optimization, I hesitated about whether to use pass by value or pass by reference. Pass by value pattern using RETURNING keyword:
ABAP传值和传引用的性能比较 - pass by value VS pass by reference