今天我在寫程式的時候,碰到這樣一個問題,
就是把一個單精確度的數轉換為一個整型資料,結果發現輸出結果跟實際不一樣。
int result=System.Convert.ToInt32(5.6);//result=6;
int result1=System.Convert.ToInt32(5.3); //result1=5
我想有很多人對這個結果都有些奇怪吧,其實剛開始看到這個結果我也是一樣。
也許早有人知道這是為什麼,但我還是要說一下原因:就是這個方法對資料進行了處理。
其實不用我說我想大家也應該看的出來的哦。
這個方法只對對它的兩個重載進行了這種處理。
但真正意義上說只對它的一個方法進行了四捨五入處理。
public static int ToInt32(double val)//對它進行了處理
{
if (val >= 0)
{
if (val >= int.MaxValue)
{
throw new OverflowException(Environment.GetResourceString("Overflow_Int32"));
}
int num1 = (int) val;
double num2 = val- num1;
if ((num2 > 0.5) || ((num2 == 0.5) && ((num1 & 1) != 0)))
{
num1++;
}
return num1;
}
if (value >= int.MinValue)
{
int num3 = (int) val;
double num4 = val - num3;
if ((num4 < -0.5) || ((num4 == -0.5) && ((num3 & 1) != 0)))
{
num3--;
}
return num3;
}
}
public static int ToInt32(float val)
{
return ToInt32((double)val);
}
希望對大家有點協助。