Intrigué par cette question sur les boucles infinies en perl: while (1) Vs. for (;;) Y a-t-il une différence de vitesse? , J'ai décidé de lancer une comparaison similaire en python. Je m'attendais à ce que le compilateur génère le même code d'octet pour while(True): passet while(1): pass, mais ce n'est en fait pas le cas en python2.7.
Le script suivant:
import dis
def while_one():
while 1:
pass
def while_true():
while True:
pass
print("while 1")
print("----------------------------")
dis.dis(while_one)
print("while True")
print("----------------------------")
dis.dis(while_true)
produit les résultats suivants:
while 1
----------------------------
4 0 SETUP_LOOP 3 (to 6)
5 >> 3 JUMP_ABSOLUTE 3
>> 6 LOAD_CONST 0 (None)
9 RETURN_VALUE
while True
----------------------------
8 0 SETUP_LOOP 12 (to 15)
>> 3 LOAD_GLOBAL 0 (True)
6 JUMP_IF_FALSE 4 (to 13)
9 POP_TOP
9 10 JUMP_ABSOLUTE 3
>> 13 POP_TOP
14 POP_BLOCK
>> 15 LOAD_CONST 0 (None)
18 RETURN_VALUE
L'utilisation while Trueest nettement plus compliquée. Pourquoi est-ce?
Dans d'autres contextes, python agit comme s'il était Trueégal à 1:
>>> True == 1
True
>>> True + True
2
Pourquoi whiledistingue les deux?
J'ai remarqué que python3 évalue les instructions en utilisant des opérations identiques:
while 1
----------------------------
4 0 SETUP_LOOP 3 (to 6)
5 >> 3 JUMP_ABSOLUTE 3
>> 6 LOAD_CONST 0 (None)
9 RETURN_VALUE
while True
----------------------------
8 0 SETUP_LOOP 3 (to 6)
9 >> 3 JUMP_ABSOLUTE 3
>> 6 LOAD_CONST 0 (None)
9 RETURN_VALUE
Y a-t-il un changement dans python3 dans la façon dont les booléens sont évalués?