如何解决将String转换为Int和精度损失
| 我在将类似“ 129.70”的字符串转换为整数(在这种情况下为12970)时遇到了一些问题。这是我写的功能:public static int valToInt(string v)
{
int tmp = (int)(double.Parse(v,new System.Globalization.CultureInfo(\"en-US\")) * 1000);
return tmp / 10;
}
我用* 1000然后/ 10的技巧解决了这个问题,它在99%的情况下都能正常工作,但是129.70似乎是一个临界值,并转换为12969。
有没有办法进行转换而不会造成任何损失?作为货币值,最多只能有两个十进制数字...
解决方法
public static int valToInt(string v)
{
return (int)(Decimal.Parse(v,new System.Globalization.CultureInfo(\"en-US\")) * 100m);
}
您是否真的需要一个“偏移量” int?考虑将值保留为十进制。
,为什么不从字符串中除去小数位然后解析呢?
,我已经读过很多关于“为什么整数和双精度比小数精度不高”的评论,但是简单的答案是使用小数。有关为什么的一些参考:
http://msdn.microsoft.com/zh-cn/library/364x0z75%28v=vs.80%29.aspx
http://msdn.microsoft.com/zh-cn/library/yht2cx7b%28v=vs.80%29.aspx
,浮点值本质上确实具有精度限制。将其乘以1000不会使其更精确,只是无法精确表示该数字。
当您在将数字转换为int
时将其截断时,会夸大任何精度损失。如果在将其转换为int
之前,其值类似于129699.99999999,则您将只对小数点进行斩波并以129699结尾。也可以将其舍入为正确的值,但是整数除法将截取更多数据,给您12969而不是12970。
只需乘以100,四舍五入,然后转换为int
:
public static int valToInt(string v) {
return (int)Math.Round(Double.Parse(v,new System.Globalization.CultureInfo(\"en-US\")) * 100.0);
}
,试试这个很简单...
public static int valToInt(string v)
{
return int.Parse(v.Replace(\".\",\"\"));
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。