zoukankan      html  css  js  c++  java
  • C#中Convert.ToInt32、int.TryParse、(int)和int.Parse四者的区别

    C#中Convert.ToInt32、int.TryParse、(int)和int.Parse四者的区别
    Convert.ToInt32、(int)和int.Parse三者的区别:

    首先:Convert.ToInt32 适合将object类类型转换成int类型,如Convert.ToInt32(session["shuzi"]);

    (int)适合简单数据类型之间的转换;

    int.Parse适合将string类类型转换成int类型,如int.Parse(session["shuzi"].ToString())。

    (1)这两个方法的最大不同是它们对null值的处理方法:

    Convert.ToInt32(null)会返回0而不会产生任何异常,但int.Parse(null)则会产生异常。

    没搞清楚Convert.ToInt32和int.Parse()的细细微区别时千万别乱用,否则可能会产生无法预料的结果。

    举例来说:假如从url中取一个参数page的值,我们知道这个值是一个int,所以即可以用Convert.ToInt32(Request.QueryString["page"]),也可以用,int.Parse(Request.QueryString["page"]),但是如果page这个参数在url中不存在,那么前者将返回0,0可能是一个有效的值,所以你不知道url中原来根本就没有这个参数而继续进行下一下的处理,这就可能产生意想不到的效果,而用后一种办法的话没有page这个参数会抛出异常,我们可以捕获异常然后再做相应的处理,比如提示用户缺少参数,而不是把参数值当做0来处理。

    (2)还有一点区别就是

    a. Convert.ToInt32(double value) 如果 value 为两个整数中间的数字,则返回二者中的偶数;即 3.5转换为4,4.5 转换为 4,而 5.5 转换为 6。 不过4.6可以转换为5,4.4转换为4

    b. int.Parse("4.5") 直接报错:"输入字符串的格式不正确".

    c. int(4.6) = 4 Int转化其他数值类型为Int时没有四舍五入,强制转换

    int.Parse是转换String为int Convert.ToInt32是转换继承自Object的对象为int的. 你得到一个object对象,你想把它转换为int,用int.Parse就不可以,要用Convert.ToInt32.

    总结:

    (1)Convert.ToInt32的参数比较多,Int.Parse只能转换string类型的.

    (2)Parse就是把String转换成int,char,double....等,也就是*.Parse(string) 括号中的一定要是string.

    (3)Convert可以提供多种类型的转换,也就搜索是Convert.*()括号中可以为很多种类型(包括string).

    追加:关于int.TryParse

    int.TryParse(input, out i)

    第一个参数为要转化的值,第二个参数为输出值,如果转换失败,输出值为 0,如果转换成功,输出值为转换后的int值

    关于int.TryParse(input, out i),该表达式转换成功返回 true,转换失败返回 false。

    string input = "123";
    int i = 0;
    if (int.TryParse(input, out i))
    {
      Console.WriteLine(i);
    }
    else
    {
      Console.WriteLine(i);
    }

    输出的结果为123。

    由上可知:int.TryParse()也可用作判断用户输入的值是否为整数。

  • 相关阅读:
    java API 文档
    java容器
    java学习笔记 java.io.File类
    理解性能的奥秘——应用程序中慢,SSMS中快(1)——简介
    第六章——根据执行计划优化性能(3)——键值查找
    第六章——根据执行计划优化性能(2)——查找表/索引扫描
    第六章——根据执行计划优化性能(1)——理解哈希、合并、嵌套循环连接策略
    SQL Server 执行计划操作符详解(3)——计算标量(Compute Scalar)
    SQL Server 执行计划操作符详解(2)——串联(Concatenation )
    SQL Server 执行计划操作符详解(1)——断言(Assert)
  • 原文地址:https://www.cnblogs.com/feipengting/p/9996400.html
Copyright © 2011-2022 走看看