views:

536

answers:

2

I am getting a CA1305 Warning.

Microsoft.Globalization : Because the behavior of 'int.Parse(string)' could vary based on the current user's locale settings, replace this call in '_Default.CalculateImageButton_Click(object, ImageClickEventArgs)' with a call to 'int.Parse(string, IFormatProvider)'. If the result of 'int.Parse(string, IFormatProvider)' will be displayed to the user, specify 'CultureInfo.CurrentCulture' as the 'IFormatProvider' parameter. Otherwise, if the result will be stored and accessed by software, such as when it is persisted to disk or to a database, specify 'CultureInfo.InvariantCulture'.

What exactly can go wrong if I omit specifying the culture when parsing Int32?

+5  A: 

It means that when you read "1,234" from a data file or Database record, then try to cast it to an Int via Parse, you'll get 1234 in America and 1 in Germany. The warning gives good advice - if you're interacting with the user, specify CurrentUiCulture, and if you're interacting with a filesystem or database (or anything !user), use InvariantCulture

Paul Betts
I believe CurrentUICulture is ONLY for pulling string resources out. For all formatting, you should use CurrentCulture (notice lack of UI). Otherwise, certain cultures will cause your code to throw.See http://code.google.com/p/dotnetopenid/issues/detail?id=60 for an example of a bug caused by this.
Andrew Arnott
+1  A: 

If you are parsing an integer, it may have thousand separators, which can be "," or "." depending on the locale.

tekBlues