當使用區域性信息時,將數字轉換爲雙精度值時出現奇怪的行爲。
使用荷蘭文化轉換"3,3"
時,處理正確。如果我使用美國文化轉換"3,3"
,則返回33
。我期待着一個錯誤。看我的例子:將小數點分隔符錯誤地轉換爲雙數
static void Main(string[] args)
{
CultureInfo cultureDutch = new CultureInfo("nl-NL");
CultureInfo cultureUS = new CultureInfo("en-US");
System.Threading.Thread.CurrentThread.CurrentCulture = cultureDutch;
Console.WriteLine("Input 3,3 --> Expected 3,3");
Console.WriteLine("Output = " + Convert.ToDouble("3,3", cultureDutch));
// Actual result --> 3,3
Console.WriteLine("Input 3,3 --> Expected InvalidCastException");
Console.WriteLine("Output = " + Convert.ToDouble("3,3", cultureUS));
// Actual result --> 33
Console.WriteLine();
Console.WriteLine();
System.Threading.Thread.CurrentThread.CurrentCulture = cultureUS;
Console.WriteLine("Input 3.3 --> Expected InvalidCastException");
Console.WriteLine("Output = " + Convert.ToDouble("3.3", cultureDutch));
// Actual result --> 33
Console.WriteLine("Input 3.3 --> Expected 3.3");
Console.WriteLine("Output = " + Convert.ToDouble("3.3", cultureUS));
// Actual result --> 3.3
Console.ReadLine();
}
什麼是正確的方法來處理?當小數點(或千位)分隔符無效時,我更喜歡一個例外。
逗號是千位分隔符,.NET對用戶放置位置沒有挑剔。或者像印度人那樣,用戶有不規則的模式。你需要追求真正的解決方案,並知道用戶說什麼語言。這從來不是一個真正的問題,它是Thread.CurrentCulture。當你說荷蘭語時,你只會遇到這個問題,假裝不是來自荷蘭,而是不告訴操作系統。 –