print公式原理

更新时间:02-07 教程 由 情念 分享

print公式原理?

print 函数原理如下:

import inspect

frame = None

def foo():

bar()

def bar():

global frame

frame = inspect.currentframe()

pass

# python解释器 python.exe 会用一个叫做PyEval_EvalFrameEx(c语言函数)去执行foo函数,首先会创建一个栈帧(stack frame),

"""

python在运行前会编译成字节码对象

当foo调用bar函数进,又会创建一个栈帧,

关键是所有的栈帧都是分配在堆内存, 堆内存有个特点,不手动释放,就会一直存在

这就决定了栈帧可以独立于调用者存在.

"""

# import dis

# print(dis.dis(foo)) # 查看foo函数的字节码

foo() #先调用一下foo函数 ,这个frame就有值.

print(frame.f_code.co_name) # bar 查看这个栈帧, bar 所以还是可以拿到bar的栈帧,然后就可以调用bar函数

caller_frame = frame.f_back # 当前frame栈帧的调用者的栈帧

print(caller_frame.f_code.co_name) # foo , 也可以拿到bar函数的栈帧

python中函数的调用就是创建栈帧的过程,而这些创建的栈帧都是存放在堆上面,不释放就永久存在,所以我们拿到每个函数对应的栈帧,就可以调用这个函数.

声明:关于《print公式原理》以上内容仅供参考,若您的权利被侵害,请联系13825271@qq.com
本文网址:http://www.25820.com/tutorial/14_2281740.html