共计 1332 个字符,预计需要花费 4 分钟才能阅读完成。
最近 flutter 很火,火的简直周边的小伙伴都开始学习这个跨平台新框架,作为一名 优良的前端 折腾师,那必定的连忙学起来了,然而在浮点数计算的时候,却遇到了与前端同样的问题,精度舍入问题。
举个栗子:
0.1 + 0.2 = 0.30000000000000004
1.0 - 0.9 = 0.09999999999999998
0.105.toStringAsFixed(2) = 0.1 // not 0.11
具体的起因这里不再叙述,读者可自行 Google。
那在前端畛域个别咱们都是应用第三方库进行浮点数的计算,这里笔者常常应用的库则是 number-precision, 这个库的核心思想是应用放大放大法进行精度的精确计算,譬如 0.1 + 0.2
咱们能够转换为 1 + 2
等于 3
, 而后咱们将其再放大10
倍就能够失去0.3
,因为整数的计算是没有精度问题的,所以刚好能够奇妙的解决这个问题。
在 dart
中咱们能够同样应用这个放大放大法进行浮点数的精确计算,在这里为了不便前端开发人员无缝切入,笔者基于 number-precision 的 api
进行形象封装开发了 number_precisiondart
版本, 现已正式公布 1.0.0 版本,欢送广大读者进行装置应用,语法糖放弃和 number-precision 截然不同,轻量简洁且不依赖第三方库。
装置应用
找到我的项目的 pubspec.yaml
文件,增加以下代码:
dependencies:
number_precision: ^1.0.0+1
办法
NP.strip(num) // 将浮点数改正为正确的小数
NP.plus(num1, num2, [num3, ...]) // 加法, num + num2 + num3, 第一二参数为必选项
NP.minus(num1, num2, [num3, ...]) // 减法, num1 - num2 - num3
NP.times(num1, num2, [num3, ...]) // 乘法, num1 * num2 * num3
NP.divide(num1, num2, [num3, ...]) // 除法, num1 / num2 / num3
NP.round(num, ratio) // 保留 ratio 位小数
应用
import 'package:number_precision/number_precision.dart';
NP.strip(0.09999999999999998); // = 0.1
NP.plus(0.1, 0.2); // = 0.3, not 0.30000000000000004
NP.plus(2.3, 2.4); // = 4.7, not 4.699999999999999
NP.minus(1.0, 0.9); // = 0.1, not 0.09999999999999998
NP.times(3, 0.3); // = 0.9, not 0.8999999999999999
NP.times(0.362, 100); // = 36.2, not 36.199999999999996
NP.divide(1.21, 1.1); // = 1.1, not 1.0999999999999999
NP.round(0.105, 2); // = 0.11, not 0.1
开源不易,欢送 pr 以及 star,我的项目地址 number_precision, 如有谬误,愿不吝赐教。
正文完