Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

CA1305: int.Parse(String)

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?

like image 998
niaher Avatar asked Jun 12 '09 02:06

niaher


2 Answers

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 CurrentCulture (thanks Andrew!), and if you're interacting with a filesystem or database (or anything !user), use InvariantCulture

like image 111
Ana Betts Avatar answered Oct 14 '22 06:10

Ana Betts


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

like image 2
tekBlues Avatar answered Oct 14 '22 06:10

tekBlues