php计算金额精度丢失问题与二维数组排序

 author:hann

(本文阅读预计5分钟)

一。前言:

  最近公司项目引入了采购金返利活动,使用采购金和返还采购金同时开始,业务规则交错,所以每一笔钱的错位都会导致后续业务计算错误。

【保证精度与计算的正确性】,很重要。

 

二。碰到问题

  开发时发现异常现象,在百分比计算返利时,有时候会多出1分钱问题,偶发。

  原因1 : 因为在单订单多商品的每个商品乘法计算四舍五入,最后累加就会有出入。

  原因2 : 由于业务形态为不一定所有商品参加返利,剔除逻辑与二维商品数组排序有关

三。解决方法

  1. 计算最后一个商品使用减法,而非乘法,即:最后一个额度 = 总额 - 已计算额度,这样永远不会精度丢失超发或少发

  2. php巧妙的二维数组按指定字段排序算法,array_multisort,两行代码搞定一个复杂排序逻辑

部分源码如下:

 

 

四.详细介绍

防止精度丢失其实就是一个运算理念,

这里着重介绍下php原装spl函数,以前小瞧它了

array_multisort();
$sort_purchase_rebate_price_arr = array_column($order_product_lists,'purchase_rebate_price');
array_multisort($sort_purchase_rebate_price_arr,SORT_ASC,$order_product_lists);

这个函数很强大,既可以计算一位数组的排序,也可以计算二维数组的排序

而且感觉百度百科介绍的比官方文档容易懂,另眼相看呀。

 

五.参考链接:

官方文档:https://php.net/manual/en/function.array-multisort.php

百度百科:https://baike.baidu.com/item/array_multisort/9038626?fr=aladdin

posted @ 2020-01-08 18:43  WidgetBox  阅读(802)  评论(0编辑  收藏  举报