如何解决bigNumber 没有正确解析以太
我有以下几点:
std::vector<...> attributes;
attributes.reserve(instances.size());
std::transform(instances.begin(),instances.end(),std::back_inserter(attributes),[](auto&& obj) { return obj.a; });
我是否遗漏了一些关于为什么 import { BigNumber } from "@ethersproject/bignumber";
import { parseUnits } from "@ethersproject/units";
const decimals = 18;
export const add = (a: string,b: string): string => {
const _a = parseUnits(a,decimals);
console.log(_a.toString(),a);
const _b = BigNumber.from(b);
const res = _a.add(_b).toString();
return res;
};
// a = 123456789123456789.123456789123456789
// b = 1
// _a.toString() = 123456789123456789123456789123456789
// res = 123456789123456789123456789123456790
不会被计算为“123456789123456790.123456789123456789”的明显信息?
即使我不传入 res
,它仍然是相同的结果。 (理想情况下我不想指定实际的小数值)
解决方法
BigNumber
实际上是一个 BigInteger(其中不能有十进制值)。这是因为在以太坊区块链上,数字表示为 256 位整数。您还可以查看同一主题的 my answer。
现在使用小数可能会令人困惑,让我这样说:
// creating BigNumber instances
const a = ethers.BigNumber.from('1') // creates BigNumber of 1
const b = ethers.utils.parseUnits('1',18) // Creates BigNumber of 1000000000000000000
const c = ethers.utils.parseEther('1') // same as above,by default 18 decimals
a.toString() // '1'
b.toString() // '1000000000000000000'
ethers.utils.formatEther(a) // '0.000000000000000001'
ethers.utils.formatEther(b) // '1.0'
如果您主要处理带有小数的货币数字,那么您可以简单地坚持使用 parseEther
和 formatEther
实用程序。
如果您不使用货币并且它仍然是 BigNumber,那么您可以使用 BigNumber.from()
和 value.toString()
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。