go 相关库:"github.com/shopspring/decimal"
float是单精度,double是双精度,decimal是数字型,
表示小数的一共有三种类型:float是单精度,double是双精度,decimal是数字型,它们所占的内存空间不一样,表示的位数也不一样。
1、精度:
- float单精度小数部分能精确到小数点后面6位,用 32 位二进制进行描述
- double双精度小数部分能精确到小数点后的15位,,用64位二进制进行描述,比float型更精确
2、占内存及处理速度:
- float单精度内存占4个字节
- double双精度内存占8个字节,是float型的两倍,且运算速度也比float慢得多
结论:虽然double型比float型精度高,但由于占内存更大,运算速度慢,且即使是double依然会存在精度损失的问题,且不会报告任何的错误,也不会有任何的异常产生。所以如果涉及到小数计算的话,我们会用到下边的decimal型:
1、精度:
decimal用l128位高精度浮点数,常用于金融运算,不会出现浮点数计算的误差
2、占内存及处理速度:
decimal类型的数据存储形式是,将每9位十进制数存储为4个字节