ABAP高级调试功能

合集下载

SAPABAP性能优化

SAPABAP性能优化

SAPABAP性能优化SAPABAP(高级商务应用编程语言)是一种面向SAP应用程序开发的编程语言。

在开发SAPABAP应用程序时,性能优化是非常重要的,可以提高应用程序的响应速度和效率。

以下是一些优化SAPABAP性能的技术和实践。

1.数据库访问优化:在数据库访问方面,以下几种方法可以提高性能:-尽量避免对数据库频繁的读写操作,尽量减少数据库访问的次数。

-使用WHERE语句来限制查询结果的数量,尽量避免返回大量数据。

-使用索引来加速数据库查询操作。

对于频繁访问的字段,可以创建相应的索引。

-避免在循环中进行数据库查询操作,可以将多次查询合并为一次查询,提高效率。

2.代码优化:在编写ABAP代码时,以下几种方法可以提高性能:-避免使用SELECT*语句,尽量只选择需要的字段。

-避免在循环中进行复杂的计算操作,可以将计算提取到循环之外,减少计算次数。

-避免频繁使用长字段,例如TEXT字段,可以将其存储在辅助表中,减少数据库访问次数。

-使用内表来处理数据,避免频繁的数据库访问。

3.内存优化:在使用内存方面,以下几种方法可以提高性能:-尽量减少内存的使用,避免无用的变量和数据结构占用过多内存。

-对于大量数据的处理,可以使用ITAB或HASHEDTABLE来提高效率,尽量避免使用SORTEDTABLE。

-注意内存泄漏问题,及时释放不再使用的内存空间。

4.并发处理优化:在处理并发操作时,以下几种方法可以提高性能:-使用合适的锁策略,避免死锁和长时间的等待。

-尽量避免对同一个资源进行频繁的读写操作,可以考虑其他方法来减少并发冲突。

-使用事务控制来保证数据的一致性和完整性。

-如果可能,可以将并发操作分解成多个较小的操作,减少并发冲突的可能性。

5.缓存优化:在使用缓存方面,以下几种方法可以提高性能:- 使用合适的缓存技术,例如SAP的共享内存(Shared Memory)和缓冲区(Buffers)。

-对于频繁使用的数据,可以将其缓存在共享内存中,提高访问速度。

abap debug 技巧

abap debug 技巧

1. 静态menu/button设置debug: 用户相关如今的系统(因为debug是与系统有关的),屏幕上可以有两种类型的debug mode:当然,这两个break-point都是用户相关的,也就是说不同的用户是不会相互影响的。

(1)Set/Delete session break-point前一种:同一个logon session,也就是说,在同一个登录session中,它的状态是保持着的。

如下:先设置一个session break-point:设置break-point:然后再打开另一个session,同样看该program:发现该break-point仍然存在。

如果再重新登录,再打开该program:可以发现,break-point不见了。

(2)Set/Delete External break-point后一种:不同的logon session,范围大于(包括)前一种。

先设置一个session break-point和external breakpoint:然后再打开另一个session,同样看该program,发现该两个break-point仍然存在。

如果再重新登录,再打开该program,可以发现,只有external 的break-point存在了。

2. Coding中设置debug:用户无关与用户相关这里仅记录两个break-point以及break <User>:(1)Break-Point:用户无关Break-point:是与用户无关。

如在程序中定义:然后,执行会进入debug。

如果再换一个用户(非当前的用户),同样会进入到debug中去。

(2)Break <userID>:用户相关Break <userID>:是与用户相关。

如在程序中定义:然后,执行会进入debug。

如果再换一个用户(非当前的用户),则不会进入到debug中去。

3. Debug中操作(1)设置Watch Point在Debug中设置watch point主要是为了在debug中有条件地去执行程序,类似于在程序中设置了一道“门槛”,程序运行至此则停下来。

ABAP高级调试功能

ABAP高级调试功能
SAT 程序流分析 –追踪并行进程
ABAP运行时分析器 – 用户追踪
追踪并行会话很不错,但是… HTTP 请求 (佚名HTTP 用户) RFC请求(RFC用户)
需要ABAP用户追踪
后台作业或者别的用户启动的业务 - 开始的时间未知
© 2010 SAP AG. All rights reserved. / Page 30
ABAP运行时分析器 – SAT – 性能分析
© 2010 SAP AG. All rights reserved. / Page 34
ABAP运行时分析器 – 性能问题
策略
尽量多地限定跟踪文件 (

变式). 特别是运行时间很长的程序。否则很快超出文件大小限制。
启动跟踪要以“按调用”(by call)来合计(结果只有命中列表) 限定语句– 例如:仅模块 (functions, forms, methods …) 在第二次追踪中缩小分析范围,用以追踪使性能最差的模块 只跟踪在“Limitation on Program Components”中定义的模块。
?重用新调试器界面框架获得先进且灵活的界面?不产生本地追踪文件可通过系统所有服务器来访问中央追踪容器?提供便利的跳转功能例如从调用层次到命中列表等等在各个视图之间灵活切换?使用profiletool检查哪个包层程序占用最多时间?针对每条调用层次项均可访问其调用堆栈?除了详细的调用层次分析以外还提供了一个模块树工具用以显示调用堆栈的合计视图
3. ABAP 单元测试器– 生成测试单元对每个功能模块进行测试
4. 覆盖分析器 –通过测试确保程序里每个单元都被执行到
© 2010 SAP AG. All rights reserved. / Page 5

[调整ABAP程序的性能]

[调整ABAP程序的性能]

如何调整ABAP程序的性能1、使用where语句不推荐Select * from zflight.Check : zflight-airln = ‘LF’ and zflight-fligh = ‘BW222’.Endselect.推荐Select * from zflight where airln = ‘LF’ and fligh = ‘222’.Endselect.2、使用聚合函数不推荐Maxnu = 0.Select * from zflight where airln = ‘LF’ and cntry = ‘IN’.Check zflight-fligh > maxnu.Maxnu = zflight-fligh.Endselect.推荐Select max( fligh ) from zflight into maxnu where airln = ‘LF’ and cntr y = ‘IN’.3、使用视图代替基本表查询不推荐Select * from zcntry where cntry like ‘IN%’.Select single * from zflight where cntry = zcntry-cntry and airln = ‘LF’.Endselect.推荐Select * from zcnfl where cntry like ‘IN%’ and airln = ‘LF’.Endselect.4、使用INTO table 代替select endselect不推荐Refresh: int_fligh.Select * from zflight into int_fligh.Append int_fligh. Clear int_fligh.Endselect.推荐Refresh: int_fligh.Select * from zflight into table int_fligh.5、使用批量修改内表代替逐行修改不推荐Loop at int_fligh.If int_fligh-flag is initial.Int_fligh-flag = ‘X’.Endif.Modify int_fligh.Endloop.推荐Int_fligh-flag = ‘X’.Modify int_fligh transporting flag where flag is initial.6、使用二分法查询,提高查询内表数据速度不推荐Read table int_fligh with key airln = ‘LF’.推荐Read table int_fligh with key airln = ‘LF’ binary search.7、两个内表添加使用批量增加代替逐行不推荐Loop at int_fligh1.Append int_fligh1 to int_fligh2.Endloop.推荐Append lines of int_fligh1 to int_fligh2.8、使用table bufferingUse of buffered tables is recommended to improve the performance considerab ly. The buffer is bypassed while using the following statementsSelect distinctSelect … for updateOrder by, group by, having clauseJoinsUse the Bypass buffer addition to the select clause in order to explicitly bypas s the buffer while selecting the data.9、使用FOR ALL Entries不推荐Loop at int_cntry.Select single * from zfligh into int_flighwhere cntry = int_cntry-cntry.Append int_fligh.Endloop.推荐Select * from zfligh appending table int_flighFor all entries in int_cntryWhere cntry = int_cntry-cntry.10、正确地使用where语句,使查询能使用索引When a base table has multiple indices, the where clause should be in the ord er of the index, either a primary or a secondary indexTo choose an index, the optimizer checks the field names specified in the whe re clause and then uses an index that has the same order of the fields. One more tip is that if a table begins with MANDT, while an index does not, there is a high possibility that the optimizer might not use that index.11、正确地使用MOVE语句Instead of using the move-corresponding clause it is advisable to use the move statement instead. Attempt should be made to move entire inter nal table headers in a single shot, rather than moving the fields one by one.12、正确地使用inner joinLet us take an example of 2 tables, zairln and zflight. The table zairln has t he field airln, which is the airline code and the field lnnam, which is the name of the airline. The table zflight has the field airln, the airline code and other f ields which hold the details of the flights that an airline operates.Since these 2 tables are logically joined by the airln field, it is advisable to use the inner join.Select a~airln a~lnnam b~fligh b~cntry into table int_airdetFrom zairln as a inner join zflight as b on a~airln = b~airln.In order to restrict the data as per the selection criteria, a where clause can be added to the above inner join.13、使用sort by 代替order by14、避免使用SELECT DISTINCT语句使用的ABAP SORT + DELETE ADJACENT DUPLICATES 代替.15、使用select 字段列表代替Select *不推荐SELECT * FROM DD01L INTO DD01L_WAWHERE DOMNAME LIKE 'CHAR%'AND AS4LOCAL = 'A'.ENDSELECT.推荐SELECT DOMNAME FROM DD01LINTO DD01L_WA-DOMNAMEWHERE DOMNAME LIKE 'CHAR%'AND AS4LOCAL = 'A'.ENDSELECT.16、使用subquery代替多个select语句不推荐SELECT * FROM SPFLIINTO TABLE T_SPFLIWHERE CITYFROM = 'FRANKFURT'AND CITYTO = 'NEW YORK'.SELECT * FROM SFLIGHT AS FINTO SFLIGHT_WAFOR ALL ENTRIES IN T_SPFLIWHERE SEATSOCC < F~SEATSMAXAND CARRID = T_SPFLI-CARRIDAND CONNID = T_SPFLI-CONNIDAND FLDATE BETWEEN '19990101' AND '19990331'. ENDSELECT.推荐SELECT * FROM SFLIGHT AS F INTO SFLIGHT_WA WHERE SEATSOCC < F~SEATSMAXAND EXISTS ( SELECT * FROM SPFLIWHERE CARRID = F~CARRIDAND CONNID = F~CONNIDAND CITYFROM = 'FRANKFURT'AND CITYTO = 'NEW YORK' )AND FLDATE BETWEEN '19990101' AND '19990331'. ENDSELECT.17、如何快速删除重复内表的记录不推荐READ TABLE ITAB INDEX 1 INTO PREV_LINE.LOOP AT ITAB FROM 2 INTO WA.IF WA = PREV_LINE.DELETE ITAB.ELSE.PREV_LINE = WA.ENDIF.ENDLOOP.推荐DELETE ADJACENT DUPLICATES FROM ITABCOMPARING K.18、如何快速删除内表一定范围内的记录不推荐DO 101 TIMES.DELETE ITAB INDEX 450.ENDDO.推荐DELETE ITAB FROM 450 TO 550.19、使用collect语句代替人工合计计算结果不推荐LOOP AT ITAB1 INTO WA1.READ TABLE ITAB2 INTO WA2 WITH KEY K = WA1-K BINARY SEARCH. IF SY-SUBRC = 0.ADD: WA1-VAL1 TO WA2-VAL1,WA1-VAL2 TO WA2-VAL2.MODIFY ITAB2 FROM WA2 INDEX SY-TABIX TRANSPORTING VAL1 VAL2. ELSE.INSERT WA1 INTO ITAB2 INDEX SY-TABIX.ENDIF.ENDLOOP.推荐LOOP AT ITAB1 INTO WA.COLLECT WA INTO ITAB2.ENDLOOP.SORT ITAB2 BY K.20、使用显示的work area 代替默认的work area不推荐ITAB = WA.APPEND ITAB.推荐APPEND WA TO ITAB.21、使用LOOP ...ASSIGNING代替loop ... modify. 不推荐(整条记录更新)LOOP AT ITAB INTO WA.I = SY-TABIX MOD 2.IF I = 0.WA-FLAG = 'X'.MODIFY ITAB FROM WA.ENDIF.ENDLOOP.推荐(只会更新需要修改内容)LOOP AT ITAB ASSIGNING <WA>.I = SY-TABIX MOD 2.IF I = 0.<WA>-FLAG = 'X'.ENDIF.ENDLOOP.。

abap调试标准alv -回复

abap调试标准alv -回复

abap调试标准alv -回复什么是ABAP调试?ABAP(Advanced Business Application Programming)是一种用于SAP系统的编程语言,它允许开发人员根据特定业务需求创建和修改SAP应用程序。

而ABAP调试则是一种用于诊断和修复ABAP程序中的错误和问题的技术工具。

ABAP调试标准ALV是ABAP调试的一种常用工具,它提供了一种可视化的方式来查看程序内部状态和执行流程,使开发人员能够更加方便地定位和修复错误。

那么,ABAP调试标准ALV 是如何使用的呢?下面我们将一步一步回答这个问题。

第一步:启动调试模式在调试ABAP程序之前,首先需要将程序启动到调试模式。

有多种方式可以启动调试模式,最简单的方式是在SAP Easy Access主界面上使用快捷键“Ctrl+Shift+F8”,或者在菜单栏选择“系统”→“工具”→“ABAP程序调试”。

第二步:设置断点一旦程序在调试模式中运行,开发人员就可以根据需要在程序中设置断点。

断点是一种指示程序执行暂停的标记,可以将断点设置在关键代码的位置,以便检查程序运行到该位置时的内部状态。

要设置断点,只需在代码行上单击鼠标右键,然后选择“断点设置”。

第三步:运行程序设置断点后,可以开始运行程序。

根据程序的逻辑,程序将在设置断点处停止执行,等待开发人员进一步操作。

可以通过单击SAP界面上的绿色箭头按钮或使用快捷键“F8”来继续程序的执行。

第四步:观察内部状态当程序执行到断点时,调试工具会显示程序的内部状态。

可以查看各个变量的值、调用栈、当前执行的代码行等信息。

这些信息将帮助开发人员找出程序错误或异常的原因。

第五步:修改代码一旦开发人员定位到程序中的问题,就可以对代码进行修改。

可以通过编辑器界面直接对代码进行修改,也可以使用调试工具提供的功能来修改变量的值、跳转到不同的代码行等操作。

第六步:继续执行或单步执行修改代码后,可以选择继续执行程序或者单步执行程序来验证修改的效果。

abap debug技巧

abap debug技巧

abap debug技巧ABAP Debug技巧1. 概述ABAP Debug技巧是在ABAP开发中用于调试和定位错误的重要工具。

本文将介绍几种常用的ABAP Debug技巧,以帮助开发者快速定位问题并进行调试。

2. 断点调试•设置断点: 使用BREAK-POINT语句在代码中设置断点,当程序执行到该断点时会暂停执行。

例如:BREAK-POINT.•条件断点: 可以在断点设置时添加条件,只有满足条件时才会暂停执行。

例如:BREAK-POINT ID 'COND_BREAKPOINT' IFlv_variable = 'ABC'.•动态断点: 使用DYNAMIC BREAK-POINT语句在运行时设置断点。

例如:DYNAMIC BREAK-POINT 'Z_MY_PROGRAM''Z_MY_FORM'.3. 查看变量•使用WATCHPOINT语句: 在代码中设置WATCHPOINT以监视变量的值。

例如:WATCHPOINT lv_variable.当该变量的值发生变化时,程序会暂停执行。

•直接查看变量: 可以在断点暂停执行时,使用鼠标右键点击变量并选择“Display”或“Evaluate”,来查看变量的当前值。

•使用变量监视器: 在调试时,可以使用变量监视器来实时监视变量的值。

在调试视图的“监视”标签页中添加要监视的变量,并可以选择刷新频率。

4. 调试窗口•全局断点视图: 在调试时,可以点击“全局断点”视图查看已设置的断点,并可以控制是否激活或禁用特定的断点。

•断点列表视图: 在调试时,可以点击“断点列表”视图查看已设置的断点,并可以快速跳转到具体的断点位置。

•断点堆栈视图: 在调试时,可以点击“断点堆栈”视图查看当前堆栈的断点信息,并可以跳转到调用堆栈上一层的断点。

5. 运行时间调试•单步执行: 在调试时,可以逐行或逐过程执行代码,以便观察执行过程。

ABAP程序性能优化的一些做法

ABAP程序性能优化的一些做法

ABAP程序性能优化的一些做法ABAP程序性能优化的一些做法ABAP程序基本上都需要从数据库里面抓数,所以性能很重要,同时有一些基本的,和优秀的写法是我们必须要掌握的,不然就会造成程序性能很差。

下面给予总结(这里包括有很基本的,也包括有比较少用到的),顺便推荐一个好的SAP标准文档 ABAP_PERFORMANCE_DOS_AND_DONTS :我觉得重要的是,1.尽量少的取数据到abap执行,多用inner join 把数据取出来。

一、基本的几条需要避免的规则(具体的一些怎么替换,可以看三和五):1、不使用select....endselect,估计月球人都知道这个事实了。

2、基本不使用select * ,跟多人喜欢直接用这个,因为方便,但是在数据量比较大的时候,应该使用select 字段,这样可以避免抓取无用数据。

3、LOOP 里面不用sort ,在loop外面排序完再进入LOOP。

4、尽量避免LOOP 里面嵌套select,这样多次访问数据库也会造成性能问题,但是有些时候避免不了也难免。

改为外面select,LOOP 里面read table。

5、大数据的read table,使用二分法 BINARY SEARCH,用之前要按关键字排序。

6、尽量避免LOOP里面嵌套LOOP,特别是当两个内表数据量都很大的时候,如果实在要嵌套LOOP可以参考三和五里面的解决办法。

7、尽量避免LOOP里面不用delete,append等语句。

改成批量处理。

二、index和buffer的合理使用:1、index的使用,在使用现有的index的时候注意,where条件里面的字段的顺序要跟index一致,而且可以可以适当的去匹配index,创建一些空的字段或者是index 后面再加字段,或者是使用index抓出数据后,再去做其它条件的处理。

2、index里面最好只有'=' AND 或者是…IN?。

有其它逻辑条件,会影响index的使用。

abap debug的五种方式

abap debug的五种方式

abap debug的五种方式
ABAP Debug是一种用于调试SAP ABAP程序的工具。

下面是ABAP Debug 的五种方式:
1. Classic Debugger:Classic Debugger是ABAP Debug的最基本版本,它允许用户在程序中设置断点、单步执行代码、查看和修改变量值以及跟踪函数调用。

用户可以通过菜单选项或快捷键直接进入Classic Debugger。

2. New Debugger:New Debugger是ABAP Debug的新版本,它比Classic Debugger更加灵活和易于使用。

New Debugger可以在不改变程序代码的情况下动态修改变量值,还可以在运行时插入代码。

此外,New Debugger还提供了更多的调试选项和功能。

3. Debugging Workbench:Debugging Workbench是一个集成了Classic Debugger和New Debugger的调试工具。

它提供了更多的调试选项和功能,如调试程序的不同层次、跟踪执行路线、检查用户权限等。

4. ABAP Trace:ABAP Trace是一种跟踪ABAP程序执行过程的工具,它可以帮助用户识别程序中的性能瓶颈和错误。

用户可以通过设置不同的跟踪选项,对程序进行跟踪并生成详细的日志信息。

5. SQL Trace:SQL Trace是一种跟踪SAP系统中数据库操作的工具,它可以帮助用户优化SQL查询语句和提高系统性能。

用户可以通过设置不同的跟踪选项,对SQL查询进行跟踪并生成详细的日志信息。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

除了详细的调用层次分析以外,还提供了一个模块树工具用以显示调用堆栈的合计视图。
通过热点分析找出事关性能及内存的要点 使用Diff tool来比较两个命中列表和调用层次
© 2010 SAP AG. All rights reserved. / Page 39
ABAP运行时分析器 – 练习
练习 2:
对程序 “ZTSTECHED_SE30_PERF” 运行SAT追踪性能,找到“性能瓶 颈” (使用 Profile Tool & Hit List 工具)。 理解为什么这个程序的性能如此低下。 通过SAT运行程序 “ZTSTECHED_SE30_PERF_OPT” ,找到性能大幅 提高的原因
通过什么方式测量?
在运行时分析的同时,系统会对上述语句的耗费时间进行测试 系统会将测试结果保存在数据库上的中央跟踪容器中 用户随时随地可以对测试结果进行评估 系统会将做测试和追踪所消耗的CPU时间从总CPU时间消耗中剔除
© 2010 SAP AG. All rights reserved. / Page 11
© 2010 SAP AG. All rights reserved. / Page 40
ABAP运行时分析器 – 小结
程序流分析 -- ABAP追踪(调用层次)
追踪ABAP语句( 寻找MESSAGE …) 从调用层次工具跳转到进程块工具,来获取调用各个层次的汇总信息


缩小追踪范围,只跟踪必要的对象 (通过显性地指定程序名或选择参数 “Limitation on Program Components”的动态方式 ) 追踪运行事务的内存消耗 (打开追踪变式中的“Measure Memory Use”选项)
ABAP 运行时分析器 – 动机
提示信息从哪里来? 我想要知道信息出来的确 切位置。
© 2010 SAP AG. All rights reserved. / Page 9
ABAP 运行时分析器 – 概 览 (I)
ABAP 运行时分析器 – 分析
程序流分析 – ABAP 跟踪
ABAP运行时分析器 – SAT – 性能分析
© 2010 SAP AG. All rights reserved. / Page 34
ABAP运行时分析器 – 性能问题
策略
尽量多地限定跟踪文件 (

变式). 特别是运行时间很长的程序。否则很快超出文件大小限制。
启动跟踪要以“按调用”(by call)来合计(结果只有命中列表) 限定语句– 例如:仅模块 (functions, forms, methods …) 在第二次追踪中缩小分析范围,用以追踪使性能最差的模块 只跟踪在“Limitation on Program Components”中定义的模块。
SAT 程序流分析 –追踪并行进程
ABAP运行时分析器 – 用户追踪
追踪并行会话很不错,但是… HTTP 请求 (佚名HTTP 用户) RFC请求(RFC用户)
需要ABAP用户追踪
后台作业或者别的用户启动的业务 - 开始的时间未知
© 2010 SAP AG. All rights reserved. / Page 30
运行时分析工具
性能 程序流 ABAP 运行时分析器(SAT / SE30) SQL 跟踪 (ST05) Dynpro 跟踪 (ST20) 调试器 Dynpro 处理
内存分析器
© 2010 SAP AG. All rights reserved. / Page 6
ABAP语言新特性(SAP NetWeaver 7.0 EhP2) – 分析 与调试
ABAP运行时分析器 – 用户追踪
WEB AS/NW以下版本可支持

6.20: SAP_BASIS SP55 + 640-Kernel PL>= 83 6.40: SAP_BASIS SP14 + 640-Kernel PL>= 83 7.00: SAP_BASIS SP03 + 700-Kernel PL>= 17

性能分析 -- ABAP追踪(命中列表)

在第一次运行时限制跟踪到模块级别,在追踪变式中使用汇总功能。 第二次运行中可以指定跟踪性能最差的模块。
• • • • • 唯一的一个可以在语句级别上追踪ABAP程序的工具(Debugger Script 除外) 定位ABAP语句 在不同的客户端或系统间对比应用程序的流程 找到某些特定的功能模块,例如,自定义的用户出口 追踪应用程序的内存使用情况
性能分析 – Hit lists
• • 判断导致程序性能低下的瓶颈在程序中的位置(ABAP vs. SQL, 某个方法 或者功能模 块) 定位导致性能低下的SQL语句或ABAP语句
© 2010 SAP AG. All rights reserved. / Page 31
Demo 演示
SAT 程序流分析– 用户追踪
ABAP运行时分析器 – 性能问题
为什么程序性能那么差?
使用ABAP运行时分析器来分 析性能,是一个最好的出发点!
© 2010 SAP AG. All rights reserved. / Page 33
© 2010 SAP AG. All rights reserved. / Page 10
ABAP 运行时分析器 – 概览(II)
哪些语句将被追踪/测量?
只有那些耗费CPU时间的ABAP语句会被追踪(不是全部ABAP语句)
耗费CPU时间显著的语句:
数据库访问: 模块单元: 内表操作: 文件处理: 其他: Select, Exec SQL, Module, CALL Function, CALL Screen, CALL Transaction, CALL Dialog Append, Collect, Sort, Read Table, Read Dataset Transfer, Open Dataset EXPORT … TO …, IMPORT … FROM …, Rollback, … SET PF-STATUS, SET TITLEBAR, MESSAGE, ASSIGN
ABAP 运行时分析器 – ABAP 追踪
© 2010 SAP AG. All rights reserved. / Page 12
SAT – 新ABAP 运行时分析器
用户 . . .
SAT
R
执行追踪
R
分析结果
SAP System SAP NW AS ABAP 虚拟机 . . . 跟踪文件 跟踪文件 SAP NW AS ABAP 虚拟机
新ABAP运行时分析器-- SAT
新ABAP调试器
-> CD263 , ABAP语言新特色
© 2010 SAP AG. All rights reserved. / Page 7
议程
1. 简介 2. SAT – 新ABAP运行时分析器 3. 新ABAP调试器
© 2010 SAP AG. All rights reserved. / Page 8
© 2010 SAP AG. All rights reserved. / Page 35
Demo 演示
SAT - 性能分析
ABAP运行时分析器 – 优势
SAT主要优势:

重用新调试器界面框架,获得先进且灵活的界面
不产生本地追踪文件,可通过系统所有服务器来访问中央追踪容器 提供便利的跳转功能 (例如从调用层次到命中列表等等),在各个视图之间灵活切换 使用Profile Tool检查哪个包/层/程序占用最多时间 针对每条调用层次项均可访问其调用堆栈
CD260 ABAP高级调试功能
SAP全球技术研发者大会(上海): 董朝明, R&D AS ABAP, SAP BP 高亚平, R&D AS ABAP, SAP CD 瞿佳乐, R&D AS ABAP, SAP CD 2010年12月
法律声明
This presentation outlines our general product direction and should not be relied on in making a purchase decision. This presentation is not subject to your license agreement or any other agreement with SAP. SAP has no obligation to pursue any course of business outlined in this presentation or to develop or release any functionality mentioned in this presentation. This presentation and SAP's strategy and possible future developments are subject to change and may be changed by SAP at any time for any reason without notice. This document is provided without a warranty of any kind, either express or implied, including but not limited to, the implied warranties of merchantability, fitness for a particular purpose, or non-infringement. SAP assumes no responsibility for errors or omissions in this document, except if such damages were caused by SAP intentionally or grossly negligent.
相关文档
最新文档