Python Language
Dis-modulen
Sök…
Konstanter i dis-modulen
EXTENDED_ARG = 145 # All opcodes greater than this have 2 operands
HAVE_ARGUMENT = 90 # All opcodes greater than this have at least 1 operands
cmp_op = ('<', '<=', '==', '!=', '>', '>=', 'in', 'not in', 'is', 'is ...
# A list of comparator id's. The indecies are used as operands in some opcodes
# All opcodes in these lists have the respective types as there operands
hascompare = [107]
hasconst = [100]
hasfree = [135, 136, 137]
hasjabs = [111, 112, 113, 114, 115, 119]
hasjrel = [93, 110, 120, 121, 122, 143]
haslocal = [124, 125, 126]
hasname = [90, 91, 95, 96, 97, 98, 101, 106, 108, 109, 116]
# A map of opcodes to ids
opmap = {'BINARY_ADD': 23, 'BINARY_AND': 64, 'BINARY_DIVIDE': 21, 'BIN...
# A map of ids to opcodes
opname = ['STOP_CODE', 'POP_TOP', 'ROT_TWO', 'ROT_THREE', 'DUP_TOP', '...
Vad är Python-bytekod?
Python är en hybridtolk. När du kör ett program samlas det först i en bytekod som sedan kan köras i Python-tolkaren (även kallad en virtuell Python-maskin ). dis
i standardbiblioteket kan användas för att göra Python-bytkoden mänskbar avläsbar genom att demontera klasser, metoder, funktioner och kodobjekt.
>>> def hello():
... print "Hello, World"
...
>>> dis.dis(hello)
2 0 LOAD_CONST 1 ('Hello, World')
3 PRINT_ITEM
4 PRINT_NEWLINE
5 LOAD_CONST 0 (None)
8 RETURN_VALUE
Python-tolkaren är stackbaserad och använder ett först-in sist-out-system.
Varje operationskod (opcode) i Python-monteringsspråket (bytekoden) tar ett fast antal objekt från stacken och returnerar ett fast antal objekt till stacken. Om det inte finns tillräckligt med objekt i bunten för en opcode kommer Python-tolkaren att krascha, eventuellt utan ett felmeddelande.
Demontering av moduler
För att ta isär en Python-modul måste den först förvandlas till en .pyc
fil (Python kompilerad). För att göra detta, kör
python -m compileall <file>.py
Kör sedan i en tolk
import dis
import marshal
with open("<file>.pyc", "rb") as code_f:
code_f.read(8) # Magic number and modification time
code = marshal.load(code_f) # Returns a code object which can be disassembled
dis.dis(code) # Output the disassembly
Detta kommer att sammanställa en Python-modul och mata ut bytekodinstruktionerna med dis
. Modulen importeras aldrig så det är säkert att använda med otillförlitlig kod.