本文實例分析了python動態性強類型用法。分享給大家供大家參考。具體如下:
Python變量聲明和定義
與C#不同,Python在使用變量之前無須定義它的類型,試著運行下面的例子:
?
1 i = 12 print i從上邊我們可以看到,變量 i 在使用前並不需要定義,但是必須聲明以及初始化該變量。試著運行下面的例子:
?
1 2 i = 1 print i + j上面的代碼會產生一個異常:“NameError: name 'j' is not defined”,Python提示變量 j 沒有定義。這點和BASIC等弱類型的語言不一樣。在BASIC中,執行上述代碼的時候不會產生異常,你可以在EXCEL的VBA開發環境裡試一下,把 print改為MsgBox就可以,結果會輸出 1 。這說明Python並不是一種類似BASIC的弱類型語言。
另一方面,Python與C#有一個很大的差異就是在程序運行過程中,同一變量名可以(在不同階段)代表不同類型的數據,看看下邊的例子:
?
1 2 3 4 5 6 i = 1 print i,type(i),id(i) i = 10000000000 print i,type(i),id(i) i = 1.1 print i,type(i),id(i)變量 i 的類型在程序執行過程中分別經歷了int、long和float的變化,這和靜態類型語言(如C等)有很大不同。靜態語言只要一個變量獲得了一個數據類 型,它就會一直是這個類型,變量名代表的是用來存放數據的內存位置。而Python中使用的變量名只是各種數據及對象的引用,用id()獲取的才是存放數 據的內存位置,我們輸入的1、10000000000和1.1三個數據均會保存在id()所指示的這些內存位置中,直到垃圾回收車把它拉走(在系統確定你 不再使用它的時候)。這是動態語言的典型特征,它確定一個變量的類型是在給它賦值的時候。
另一方面,Python又是強類型的,試著運行下邊的例子:
?
1 2 3 4 # -*- coding: utf-8 -*- i = 10; j = 'ss' print i+j #正確的寫法是print str(i)+j,輸出10ss會產生一個異常:“TypeError: unsupported operand type(s) for +: 'int' and 'str'”。在BASIC等弱類型的語言中,上邊的例子會正常運行並返回(雖然有時候是不可預期的)結果。
所以,我們說Python既是一種動態類型語言,同時也是一種強類型的語言,這點是和C#不同的地方。對於Python的這種變量的聲明、定義和使 用方式,C#程序員可能要花一段時間去適應,不過相信你會很快就喜歡上它,因為它讓事情變得更加簡單(而且不會不安全)。而且,C# 4.0 已經開始用類似的方式定義和使用變量(通過在變量名前加關鍵字dynamic),如果你先學了Python變量,將能夠更快的適應C# 4.0的動態編程特征。
希望本文所述對大家的Python程序設計有所幫助。