convert parese区别

以下两点为自己总结,并且已经经过了验证。
1,Convert.ToInt32()被重写19次,可以满足不同的参数需要
      int.Parse()被重写4次,只能转化string
2,参数为null时
              Convert.ToInt32()返回0
               int.Parse()ArgumentNullException.Value cannot be null.Parameter name: String
     参数中包含字母时包括12ab这种情况,都抛出FormatExcepton异常,Input string was not in a correct format.
所以在使用的时候假如用Convert.ToInt32()可以省掉一个ToString(),但是增加了一个对NULL的判断具体解释如下:
 
 
 
 
试验进行一亿次转换的时间,结果相同,说明这两个在将字符串转换为整数时基本没区别.(40多秒差0.x秒,应该算是没差别吧)
这两个方法的最大不同是它们对null值的处理方法:Convert.ToInt32(null)会返回0,而不会产生任何异常;但int.Parse(null)则会产生异常。
没搞清楚Convert.ToInt32和int.Parse()的细细微区别时千万别乱用,否则可能会产生无法预料的结果。
举例来说:假如从url中取一个参数ID的值,我们知道这个值是一个int,所以即可以用Convert.ToInt32 (Request.QueryString["ID"]),也可以用,int.Parse(Request.QueryString["ID"]),但是如果ID这个参数在url中不存在,那么前者将返回0,0可能是一个有效的值,所以你不知道url中原来根本就没有这个参数而继续进行下一下的处理,这就可能产生意想不到的效果,而用后一种办法的话没有ID这个参数会抛出异常,我们可以捕获异常然后再做相应的处理,比如提示用户缺少参数,而不是把参数值当做0来处理。
以下内容转自: http://blog.youkuaiyun.com/scucj/archive/2006/06/28/846344.aspx
在 C# 中,(int),Int32.Parse() 和 Convert.toInt32() 三种方法有何区别?

    int 关键字表示一种整型,是32位的,它的 .NET Framework 类型为 System.Int32。

    (int)表示使用显式强制转换,是一种类型转换。当我们从 int 类型到 long、float、double 或decimal 类型,可以使用隐式转换,但是当我们从 long 类型到 int  类型转换就需要使用显式强制转换,否则会产生编译错误。

    Int32.Parse()表示将数字的字符串转换为32 位有符号整数,属于内容转换[1]。
    我们一种常见的方法:public static int Parse(string)。
    如果 string 为空,则抛出 ArgumentNullException 异常;
    如果 string 格式不正确,则抛出 FormatException 异常;
    如果 string 的值小于 MinValue 或大于 MaxValue 的数字,则抛出 OverflowException 异常。


    Convert.ToInt32() 则可以将多种类型(包括 object  引用类型)的值转换为 int  类型,因为它有许多重载版本[2]:
    public static int ToInt32(object);
    public static int ToInt32(bool);
    public static int ToInt32(byte);
    public static int ToInt32(char);
    public static int ToInt32(decimal);
    public static int ToInt32(double);
    public static int ToInt32(short);
    public static int ToInt32(long);
    public static int ToInt32(sbyte);
    public static int ToInt32(string);
    ......


    (int)和Int32.Parse(),Convert.ToInt32()三者的应用举几个例子:    

    例子一:

    long longType = 100;
    int intType  = longType;       // 错误,需要使用显式强制转换
    int intType = (int)longType; //正确,使用了显式强制转换

    例子二:

    string stringType = "12345"; 
    int intType = (int)stringType;                //错误,string 类型不能直接转换为 int  类型 
    int intType = Int32.Parse(stringType);   //正确

    例子三:

    long longType = 100;
    string stringType = "12345";
    object objectType = "54321";
    int intType = Convert.ToInt32(longType);       //正确
    int intType = Convert.ToInt32(stringType);     //正确
    int intType = Convert.ToInt32(objectType);    //正确

    例子四[1]:

    double doubleType = Int32.MaxValue + 1.011; 
    int intType = (int)doubleType;                                //虽然运行正确,但是得出错误结果
    int intType = Convert.ToInt32(doubleType)            //抛出 OverflowException 异常 

   (int)和Int32.Parse(),Convert.ToInt32()三者的区别:

    第一个在对long 类型或是浮点型到int 类型的显式强制转换中使用,但是如果被转换的数值大于 Int32.MaxValue 或小于 Int32.MinValue,那么则会得到一个错误的结果。

    第二个在符合数字格式的 string 到 int  类型转换过程中使用,并可以对错误的 string 数字格式的抛出相应的异常。

    第三个则可以将多种类型的值转换为 int 类型,也可以对错误的数值抛出相应的异常。

    无论进行什么类型的数值转换,数值的精度问题都是我们必须考虑的[1]。

在SQL中,`CAST` 和 `CONVERT` 是两个用于数据类型转换的函数,它们的功能相似,但在具体使用场景和灵活性方面存在差异。 `CAST` 函数是符合ANSI SQL标准的,这意味着它在不同的数据库系统中具有更好的兼容性和可移植性。它主要用于将一种数据类型的表达式转换为另一种数据类型,语法较为简洁。例如,在将小数转换为整数时,`CAST` 会自动截断小数部分,而不会引发错误,这使得它在某些情况下更加实用。然而,`CAST` 的功能相对有限,尤其是在处理日期和时间格式转换时,无法提供额外的格式化选项。[^2] 相比之下,`CONVERT` 函数是Microsoft SQL Server特有的功能,它不仅支持数据类型的转换,还提供了更多的格式化选项,特别是在处理日期和时间数据时。通过使用`CONVERT`函数,用户可以指定一个样式参数(style),从而控制日期和时间值的显示格式。例如,`CONVERT`可以将日期时间值转换为特定的字符串格式,如`YYYY-MM-DD HH:MI:SS`或`YYYY/MM/DD`等。这种灵活性使得`CONVERT`在处理日期和时间数据时更为强大。[^1] ### 使用场景 - **CAST** 适用于简单的数据类型转换,尤其是在需要保证跨数据库兼容性的情况下。例如,将字符串转换为整数或浮点数,或者将数值转换为字符串等。 - **CONVERT** 更适合于需要对日期和时间数据进行格式化的情况。例如,当需要将当前日期时间转换为特定格式的字符串时,`CONVERT`提供了更多的样式选项,能够满足更复杂的需求。[^5] ### 示例 以下是一些具体的例子,展示了`CAST`和`CONVERT`的用法: ```sql -- 使用 CAST 进行类型转换 SELECT CAST('2017' AS INT) AS CastExample1; -- 输出: 2017 SELECT CAST(2017.3 AS INT) AS CastExample2; -- 输出: 2017 SELECT CAST('2017.3' AS DECIMAL) AS CastExample3; -- 输出: 2017.30 ``` ```sql -- 使用 CONVERT 进行类型转换和格式化 SELECT CONVERT(INT, '2017') AS ConvertExample1; -- 输出: 2017 SELECT CONVERT(INT, 2017.3) AS ConvertExample2; -- 输出: 2017 SELECT CONVERT(DATE, GETDATE()) AS ConvertExample3; -- 输出: 当前日期 SELECT CONVERT(VARCHAR(24), GETDATE(), 120) AS ConvertExample4; -- 输出: 2021-09-22 22:32:43 SELECT CONVERT(VARCHAR(10), GETDATE(), 102) AS ConvertExample5; -- 输出: 2021.09.22 SELECT CONVERT(VARCHAR(10), GETDATE(), 111) AS ConvertExample6; -- 输出: 2021/09/22 SELECT CONVERT(VARCHAR(10), GETDATE(), 108) AS ConvertExample7; -- 输出: 22:34:06 ``` ### 总结 尽管`CAST`和`CONVERT`都可以用于数据类型转换,但它们各自有适用的场景。`CAST`更适合于简单的、需要跨数据库兼容的数据类型转换,而`CONVERT`则在处理日期和时间数据时提供了更多的灵活性和功能性。[^1]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值