Convert.Int32、(int)和int.Parse三者的区别
| 今天去面試,碰到這樣一道題目,回來查了下答案~! Convert.ToInt32、(int)和int.Parse三者的區(qū)別: 前者適合將object類類型轉(zhuǎn)換成int類型,如Convert.ToInt32(session["shuzi"]); (int)適合簡(jiǎn)單數(shù)據(jù)類型之間的轉(zhuǎn)換; int.Parse適合將string類類型轉(zhuǎn)換成int類型,如int.Parse(session["shuzi"].ToString())。 |
?
(1)這兩個(gè)方法的最大不同是它們對(duì)null值的處理方法:
??? Convert.ToInt32(null)會(huì)返回0而不會(huì)產(chǎn)生任何異常,但int.Parse(null)則會(huì)產(chǎn)生異常。
沒搞清楚Convert.ToInt32和int.Parse()的細(xì)細(xì)微區(qū)別時(shí)千萬別亂用,否則可能會(huì)產(chǎn)生無法預(yù)料的結(jié)果,舉例來說:假如從url中取一個(gè)參數(shù)page的值,我們知道這個(gè)值是一個(gè)int,所以即可以用Convert.ToInt32(Request.QueryString["page"]),也可以用,int.Parse(Request.QueryString["page"]),但是如果page這個(gè)參數(shù)在url中不存在,那么前者將返回0,0可能是一個(gè)有效的值,所以你不知道url中原來根本就沒有這個(gè)參數(shù)而繼續(xù)進(jìn)行下一下的處理,這就可能產(chǎn)生意想不到的效果,而用后一種辦法的話沒有page這個(gè)參數(shù)會(huì)拋出異常,我們可以捕獲異常然后再做相應(yīng)的處理,比如提示用戶缺少參數(shù),而不是把參數(shù)值當(dāng)做0來處理。
(2)還有一點(diǎn)區(qū)別就是
? a. Convert.ToInt32(double value)
如果 value 為兩個(gè)整數(shù)中間的數(shù)字,則返回二者中的偶數(shù);即 3.5轉(zhuǎn)換為4,4.5 轉(zhuǎn)換為 4,而 5.5 轉(zhuǎn)換為 6。??不過4.6可以轉(zhuǎn)換為5,4.4轉(zhuǎn)換為4
? b. int.Parse("4.5")
直接報(bào)錯(cuò):"輸入字符串的格式不正確".
? c. int(4.6) = 4
Int轉(zhuǎn)化其他數(shù)值類型為Int時(shí)沒有四舍五入,強(qiáng)制轉(zhuǎn)換
int.Parse是轉(zhuǎn)換String為int
Convert.ToInt32是轉(zhuǎn)換繼承自O(shè)bject的對(duì)象為int的.
你得到一個(gè)object對(duì)象,你想把它轉(zhuǎn)換為int,用int.Parse就不可以,要用Convert.ToInt32.
個(gè)人總結(jié):
(1)Convert.ToInt32的參數(shù)比較多,Int.Parse只能轉(zhuǎn)換string類型的.
(2)Parse就是把String轉(zhuǎn)換成int,char,double....等,也就是*.Parse(string) 括號(hào)中的一定要是string.
(3)Convert可以提供多種類型的轉(zhuǎn)換,也就是Convert.*()括號(hào)中可以為很多種類型(包括string).
(4)至于效率上的區(qū)別可以看看這遍文章:《細(xì)說Convert和Parse到底那個(gè)效率高》?
轉(zhuǎn)載:http://www.cnblogs.com/flyker/archive/2009/03/04/1402673.html?login=1#commentform
轉(zhuǎn)載于:https://www.cnblogs.com/beauty/archive/2010/03/16/1687571.html
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)總結(jié)
以上是生活随笔為你收集整理的Convert.Int32、(int)和int.Parse三者的区别的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 理解 Delphi 的类(十) - 深入
- 下一篇: 基本文件上传漏洞攻击实验