问题描述
最近将软件发布到国外,老毛子朋友的很多用户反馈显示有问题,功能异常,经过查看日志一切正常,正常输出的,而且我自己测试了几遍,问过群友几遍,一切都正常,一开始怀疑是系统语言的问题,切换成英语也没复现问题。经过了一轮的日志输出,终于找到问题所在,真是一个大天坑啊!而且我的项目Android和C#都有,安卓没问题,查了下发现是这样的:
- .NET (
float.Parse,int.Parse) : 默认是区域相关的(Culture-aware) 。在俄罗斯、德国等国家,系统会期望小数点是,而不是.,导致解析"1.23"时出错或结果不正确。 - Java (
Float.parseFloat,Integer.parseInt) : 它们在底层实现上默认就是区域无关的(Invariant) 。它们始终期望用.作为小数点,且不支持千分位。所以 Android 端无论在哪个国家运行,解析逻辑都是一致的。
又涨知识了,原来有的国家浮点数是逗号分隔的,比如23.5,他们是23,5显示,所以本来数据是23.5,在我们国家是好的,但是到他们国家就解析失败了,因为他们认的是23,5的格式,就像下图,速度60.5,然后toString后就变成0,0了,因为系统认为这是个字符串。

解决办法:
本来是这样用的:
cs
float result = 0f;
float.TryParse(value, out result);
改成使用区域无关性,如下代码:
cs
/// <summary>
/// 转Float
/// </summary>
/// <param name="value"></param>
/// <returns></returns>
public static float ToFloat(string value)
{
return ToFloat(value, NumberStyles.Any, NumberFormatInfo.InvariantInfo);
}
/// <summary>
/// 转Float
/// </summary>
/// <param name="value"></param>
/// <param name="numberStyles"></param>
/// <param name="formatProvider"></param>
/// <returns></returns>
public static float ToFloat(string value,NumberStyles numberStyles,IFormatProvider formatProvider)
{
float result = 0f;
float.TryParse(value, numberStyles, formatProvider, out result);
return result;
}
而toString的地方也有参数的,也提供区域无关性NumberFormatInfo.InvariantInfo

这样就解决了!!