3 回答

TA貢獻1757條經驗 獲得超8個贊
不,名稱本身對結果代碼的運行速度沒有影響。變量名只是用來區分 Python 源代碼中由整數索引表示的兩個變量在查找表中:
>>> dis.dis('x=1')
1 0 LOAD_CONST 0 (1)
2 STORE_NAME 0 (x)
4 LOAD_CONST 1 (None)
6 RETURN_VALUE
>>> dis.dis('xyz=1')
1 0 LOAD_CONST 0 (1)
2 STORE_NAME 0 (xyz)
4 LOAD_CONST 1 (None)
6 RETURN_VALUE
>>> dis.dis('x=1;xyz=2;')
1 0 LOAD_CONST 0 (1)
2 STORE_NAME 0 (x)
4 LOAD_CONST 1 (2)
6 STORE_NAME 1 (xyz)
8 LOAD_CONST 2 (None)
10 RETURN_VALUE
在前兩個中,您會注意到在生成的字節碼中沒有基于變量名稱的區別。在最后,您將看到字節碼在兩者之間進行區分,但僅在定義它們的順序上,而不是標簽的長度上。

TA貢獻1821條經驗 獲得超5個贊
差異非常小,我們不能得出結論,這是因為變量的名稱。
import timeit
x=1
xyz=1
start_time = timeit.default_timer()
for i in range(1,1000000):
if x==1:
print("message")
elapsed = timeit.default_timer() - start_time
start_time2 = timeit.default_timer()
for i in range(1,1000000):
if xyz==1:
print("message")
elapsed2 = timeit.default_timer() - start_time2
print("small variable printing = ",str(elapsed),"big variable printing = "+str(elapsed2))
結果是:
small variable printing = 3.6490847053481588 big variable printing = 3.7199463989460435
添加回答
舉報