Convert.ToInt32與Int32.Parse區(qū)別及Int32.TryParse
更新時(shí)間:2009年01月28日 14:09:01 作者:
2個(gè)方法都可以把string轉(zhuǎn)換為int,那么他們有什么區(qū)別?什么時(shí)候該用什么?性能如何。
其實(shí)在2.0里還有Int32.TryParse也實(shí)現(xiàn)了同樣的效果。
using System;
using System.Collections.Generic;
using System.Text;
namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
string myString = "1234";
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");
}
}
}
表面上看,可見3個(gè)方法都實(shí)現(xiàn)了同樣的效果!
那么我們把代碼改一下:
//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");
運(yùn)行結(jié)果:
Convert.ToInt32()在null時(shí)不拋異常而是返回0;
Int32.Parse()要拋異常;
Int32.TryParse()不拋異常,會返回true或false來說明解析是否成功,如果解析錯(cuò)誤,調(diào)用方將會得到0值。
得出結(jié)論:
3個(gè)方法幾乎沒有差異!
如果要追求完美,那么可以參靠一下性能的差異:
Int32.TryParse()優(yōu)于Int32.Parse()優(yōu)于Convert.ToInt32()。
個(gè)人建議:.NET1.1下用Int32.Parse();.NET2.0用Int32.TryParse()。
為什么這樣呢?
因?yàn)椋篊onvert.ToInt32會把最終的解析工作代理給Int32.Parse,而Int32.Parse和Int32.TryParse則分別把解析工作直接代理給Number.ParseInt32和Number.TryParseInt32,前者在出現(xiàn)解析錯(cuò)誤時(shí)會拋出異常,而后者則僅僅返回 false。
using System.Collections.Generic;
using System.Text;
namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
string myString = "1234";
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");
}
}
}
表面上看,可見3個(gè)方法都實(shí)現(xiàn)了同樣的效果!
那么我們把代碼改一下:
//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");
運(yùn)行結(jié)果:
Convert.ToInt32()在null時(shí)不拋異常而是返回0;
Int32.Parse()要拋異常;
Int32.TryParse()不拋異常,會返回true或false來說明解析是否成功,如果解析錯(cuò)誤,調(diào)用方將會得到0值。
得出結(jié)論:
3個(gè)方法幾乎沒有差異!
如果要追求完美,那么可以參靠一下性能的差異:
Int32.TryParse()優(yōu)于Int32.Parse()優(yōu)于Convert.ToInt32()。
個(gè)人建議:.NET1.1下用Int32.Parse();.NET2.0用Int32.TryParse()。
為什么這樣呢?
因?yàn)椋篊onvert.ToInt32會把最終的解析工作代理給Int32.Parse,而Int32.Parse和Int32.TryParse則分別把解析工作直接代理給Number.ParseInt32和Number.TryParseInt32,前者在出現(xiàn)解析錯(cuò)誤時(shí)會拋出異常,而后者則僅僅返回 false。
相關(guān)文章
asp.net使用for循環(huán)實(shí)現(xiàn)Datalist的分列顯示功能
工程業(yè)績--用for循環(huán)代替了DataList多列顯示,得到2行四列的表格,需要內(nèi)存表的8行數(shù)據(jù)2009-12-12
阿里云上從ASP.NET線程角度對“黑色30秒”問題的全新分析
在這篇博文中,我們拋開對阿里云的懷疑,完全從ASP.NET的角度進(jìn)行分析,看能不能找到針對問題現(xiàn)象的更合理的解釋2015-09-09
Community Server專題三:HttpModule
Community Server專題三:HttpModule...2007-03-03
.NET Core跨平臺串口通訊使用SerialPortStream基礎(chǔ)類庫問題解決
這篇文章介紹了.NET Core跨平臺串口通訊使用SerialPortStream基礎(chǔ)類庫問題解決,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-01-01
asp.core?同時(shí)兼容JWT身份驗(yàn)證和Cookies?身份驗(yàn)證兩種模式(示例詳解)
這篇文章主要介紹了asp.core?同時(shí)兼容JWT身份驗(yàn)證和Cookies?身份驗(yàn)證兩種模式,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-02-02
Javascript 直接調(diào)用服務(wù)器C#代碼 ASP.NET Ajax實(shí)例
近來總有一些朋友會問到一些入門的問題,把這些問題整理一下,寫出來。在以前的文章里,曾經(jīng)利用純JS編寫過Ajax引擎,在真正開發(fā)的時(shí)候,大家都不喜歡以這種低效率的方式開發(fā),利用MS Ajax的集成的引擎,可以簡單不少工作。2010-03-03

