ABAP 增强中加减乘除计算结果不准(固定点计算)

问题背景
在很多标准程序debug的时候经常发现加减乘除的计算结果不对,比如5+9.5 = 100 这个计算想来想去都不知道什么原因,然后我要在增强中写个计算的校验,怎么写计算结果都不对。我该如何解决?

了解固定点计算
按照官方的解释:虽然很详细但是没怎么看懂。
在这里插入图片描述
不过我们ABAPer 一般创建程序的时候都会打上这个勾:
在这里插入图片描述
例子
如果不勾选这个勾,看看计算结果会变成什么样子:
在这里插入图片描述
代码实例

"不勾选固定点计算

DATA:lv_num1 TYPE char4,
     lv_num2 TYPE char4,
     lv_res  TYPE char4.

"计算除法
lv_num1 = '9'.
lv_num2 = '3'.
lv_res = lv_num1 / lv_num2 .
WRITE:/ lv_num1 && '/' && lv_num2 && '=' &&     lv_res.

"计算除法
lv_num1 = '9'.
lv_num2 = '3.0'.
lv_res = lv_num1 / lv_num2 .
WRITE:/ lv_num1 && '/' && lv_num2 && '=' &&     lv_res.


"计算 5 + 95
lv_num1 = '5'.
lv_num2 = '95'.
lv_res = lv_num1 + lv_num2 .
WRITE:/ lv_num1 && '+' && lv_num2 && '=' &&     lv_res.

"计算  5+ 9.5
CLEAR:lv_num1, lv_num2,lv_res.
lv_num1 = '5'.
lv_num2 = '9.05'.
lv_res = lv_num1 + lv_num2 .
WRITE:/ lv_num1 && '+' && lv_num2 && '=' &&     lv_res.

CLEAR:lv_num1, lv_num2,lv_res.
lv_num1 = '5'.
lv_num2 = '9.5'.
lv_res = lv_num1 + lv_num2 .
WRITE:/ lv_num1 && '+' && lv_num2 && '=' &&     lv_res.

"调用函数计算
CLEAR:lv_num1, lv_num2,lv_res.
lv_num1 = '5'.
lv_num2 = '9.5'.
CALL FUNCTION 'ZFM_SD_ADD'  "自定义的函数:里面代码逻辑就是  加法计算
  EXPORTING
    i_zyfk   = lv_num1
    i_ztlk   = lv_num2
    i_zdhk   = '0'
    i_zazjgk = '0'
    i_zsbtyk = '0'
    i_zzbk   = '0'
  IMPORTING
    e_he     = lv_res.
WRITE:/'调用函数' && lv_num1 && '+' && lv_num2 && '=' &&     lv_res.

然后看执行结果
在这里插入图片描述

发现其中的结果有时候对,有时候不对。
而我如果调用了勾选固定点计算的函数的计算结果是对的

结论总结
1.标准程序(未勾选固定点计算的标准程序)增强中如果有计算结果不对的情况,请调用自定义的函数进行计算。
2.如果发现自定义报表的计算结果不对,可以检查下程序属性中的固定点计算 的勾,有没有勾上。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值