如何在Python中捕獲溢位錯誤異常?
當算術運算超出變數型別的限制時,就會引發溢位錯誤。長整數在值增長時會分配更多空間,因此最終引發記憶體錯誤。但是,浮點數異常處理並未標準化。根據需要,常規整數將轉換為 long 值。
示例
給定程式碼被重寫為捕獲異常,如下所示
i=1 try: f = 3.0**i for i in range(100): print i, f f = f ** 2 except OverflowError as err: print 'Overflowed after ', f, err
輸出
我們得到以下溢位錯誤作為輸出,如下所示
C:/Users/TutorialsPoint1/~scratch_1.py Floating point values: 0 3.0 1 9.0 2 81.0 3 6561.0 4 43046721.0 5 1.85302018885e+15 6 3.43368382029e+30 7 1.17901845777e+61 8 1.39008452377e+122 9 1.93233498323e+244 Overflowed after 1.93233498323e+244 (34, 'Result too large')
廣告