今天我在写程序的时候,碰到这样一个问题,
就是把一个单精度的数转换为一个整型数据,结果发现输出结果跟实际不一样。

关于.Net中类型转换---ToInt32int result=System.Convert.ToInt32(5.6);//result=6;
    int result1=System.Convert.ToInt32(5.3); //result1=5

我想有很多人对这个结果都有些奇怪吧,其实刚开始看到这个结果我也是一样。
也许早有人知道这是为什么,但我还是要说一下原因:就是这个方法对数据进行了处理。
其实不用我说我想大家也应该看的出来的哦。
这个方法只对对它的两个重载进行了这种处理。
但真正意义上说只对它的一个方法进行了四舍五入理。

关于.Net中类型转换---ToInt32public static int ToInt32(double val)//对它进行了处理
{
关于.Net中类型转换---ToInt32            
if (val >= 0)
{
关于.Net中类型转换---ToInt32            
if (val >= int.MaxValue)
{
关于.Net中类型转换---ToInt32                   
throw new OverflowException(Environment.GetResourceString("Overflow_Int32"));
关于.Net中类型转换---ToInt32            }

关于.Net中类型转换---ToInt32            
int num1 = (int) val;
关于.Net中类型转换---ToInt32            
double num2 = val- num1;
关于.Net中类型转换---ToInt32            
if ((num2 > 0.5|| ((num2 == 0.5&& ((num1 & 1!= 0)))
{
关于.Net中类型转换---ToInt32                  num1
++;
关于.Net中类型转换---ToInt32            }

关于.Net中类型转换---ToInt32            
return num1;
关于.Net中类型转换---ToInt32      }

关于.Net中类型转换---ToInt32      
if (value >= int.MinValue)
{
关于.Net中类型转换---ToInt32            
int num3 = (int) val;
关于.Net中类型转换---ToInt32            
double num4 = val - num3;
关于.Net中类型转换---ToInt32            
if ((num4 < -0.5|| ((num4 == -0.5&& ((num3 & 1!= 0)))
{
关于.Net中类型转换---ToInt32                  num3
--;
关于.Net中类型转换---ToInt32            }

关于.Net中类型转换---ToInt32            
return num3;
关于.Net中类型转换---ToInt32      }

关于.Net中类型转换---ToInt32
关于.Net中类型转换---ToInt32  }

关于.Net中类型转换---ToInt32
public static int ToInt32(float val)
{
关于.Net中类型转换---ToInt32    
return ToInt32((double)val);
关于.Net中类型转换---ToInt32}

希望对大家有点帮助。

相关文章: