zoukankan      html  css  js  c++  java
  • 转 Convert.ToInt32与Int32.Parse区别及Int32.TryParse

    表面上看,可见3个方法都实现了同样的效果!
    那么请看:

    //string myString = "1234";
    string myString = null;
    int myint = 0;
    myint = Convert.ToInt32(myString);
    Console.Write(myint+"\r\n");
    myint = Int32.Parse(myString);
    Console.Write(myint+"\r\n");
    Int32.TryParse(myString, out myint);
    Console.Write(myint+"\r\n");

    运行结果:
    Convert.ToInt32()在null时不抛异常而是返回0;
    Int32.Parse()要抛异常;
    Int32.TryParse()不抛异常,会返回true或false来说明解析是否成功,如果解析错误,调用方将会得到0值。

    得出结论:
    3个方法几乎没有差异!

    如果要追求完美,那么可以参靠一下性能的差异:
    Int32.TryParse()优于Int32.Parse()优于Convert.ToInt32()。

    个人建议:.NET1.1下用Int32.Parse();.NET2.0用Int32.TryParse()。

    为什么这样呢?
    因为:Convert.ToInt32会把最终的解析工作代理给Int32.Parse,而Int32.Parse和Int32.TryParse则分别把解析工作直接代理给Number.ParseInt32和Number.TryParseInt32,前者在出现解析错误时会抛出异常,而后者则仅仅返回 false。

    作者:BobLiu
    邮箱:lzd_ren@hotmail.com
    出处:http://www.cnblogs.com/liuzhendong
    本文版权归作者所有,欢迎转载,未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
  • 相关阅读:
    javascript中的几种遍历方法浅析
    实用的正则表达式
    关于git中的merge和rebase
    油猴脚本-3
    油猴脚本-2
    油猴脚本-1
    hadoop各个组件之间的通信
    mysql 表数据修改的方法,单标修改、多表修改--将一张表里面的其中一个字段的值赋值给另一张表
    kafka的副本同步机制(ISR)
    sql的over函数的作用和方法
  • 原文地址:https://www.cnblogs.com/liuzhendong/p/1616161.html
Copyright © 2011-2022 走看看