频 道 直 达 - 新闻 - 培训 - 软件 - 教程 - 前沿 - 组网 - 系统应用 - 安全 - 编程 - 存储 - 操作系统 - 数据库 - 服务器 - 专题 - 产品 - 案例库 - 读书 - 博客 - BBS
51CTO.COM_中国最大的网络技术网站
找资料:

8.1.3 在Python 中访问PyFrameObject 对象

作者: 陈儒著 出处:电子工业出版社  2008-07-23 15:46    砖    好    评论   进入论坛
阅读提示:《Python源码剖析--深度探索动态语言核心技术》第8章Python 虚拟机框架,从这一章开始,我们将切入Python 字节码虚拟机,深入剖析Python 字节码虚拟机的运行机理,本小节为大家介绍的是在Python 中访问PyFrameObject 对象。

8.1.3 在Python 中访问PyFrameObject 对象

尽管PyFrameObject 对象是一个用于Python 虚拟机实现的极为隐秘的内部对象,但是Python 还是提供了某种途径可以访问到PyFrameObject 对象。在Python 中,有一种frame object,它是对C 一级的PyFrameObject 的包装。而且,非常幸运的是,Python提供的一个方法能方便地获得当前处于活动状态的frame object。这个方法就是sysmodule 中的_getframe 方法。

下面的caller.py 演示了如何利用获得当前活动的frame object,进而获取调用当前函数的函数的信息:

 [caller.py]
import sys
value = 3
def g():
frame = sys._getframe()
print 'current function is : ', frame.f_code.co_name
caller = frame.f_back
print 'caller function is : ', caller.f_code.co_name
print "caller's local namespace : ", caller.f_locals
print "caller's global namespace : ",
caller.f_globals.keys()
def f():
a = 1
b = 2
g()
def show():
f()
show()
下面是执行caller.py 的输出结果:
 [caller.py 的输出结果]
F:\PythonBook\Src\frame>python caller.py
current function is : g
caller function is : f
caller's local namespace : {'a': 1, 'b': 2}
caller's global namespace :
['g', 'f', '__builtins__', '__file__', 'show',
'value', 'sys', '__name__', '__doc__']

从执行的结果可以看到,从函数f 中我们完全获得了其调用者——函数g 的一切信息,甚至包括函数g 的各个名字空间。

有兴趣的读者可能对sys._getframe 是如何实现的很感兴趣,下面我们就给出一个利用Python 的异常机制实现和sys._getframe 功能相同的代码。frame_getter.get_current_frame 的功能和sys._getframe 的功能完全一样。

[frame_getter.py]
import sys
def get_current_frame():
try:
1/0
except Exception, e:
type, value, traceback = sys.exc_info()
return traceback.tb_frame.f_back
【责任编辑:夏书 TEL:(010)68476606】

回书目   上一节   下一节
专题
虚拟机软件入门
Python实用指南
Head First EJB(中文版)
Python源码剖析--深度探索动态语言核心技术
ActionScript 3.0权威指南
我也说两句

匿名发表

(如果看不清请点击图片进行更换)


中 国 最 大 的 网 络 技 术 网 站 ·
技 术 成 就 梦 想
订阅技术快讯
电子杂志下载
名称:SQL Server数据库管理精品黄皮书
简介:书中文章经过精挑细选,便于用户能根据自己的实际工作和学习,快速在本书寻找到相关资料。内容涵盖了SQL Server的安装与升级、语句查询、数据备份和恢复、自动化任务、数据同步、数据字典、安全和预防、性能和优化、集群等各方面应用信息,以及DBA管理人员在数据库管理工作中
名称:2007路由技术大全
简介:《2007路由技术大全》由51CTO.com网站特别策划制作,该书包括路由器技术、路由器产品、路由器配置、安全设置、路由器故障处理、路由器密码恢复,以及广大网友在实践使用中的心得经验和技巧文章,内容注重实用性,适用于初学者入门,也适合多年从业者提高,是一本实践和理论完
名称:网络安全精品应用黄皮书
简介:《2007精品网络安全黄皮书》包括了9个大类24个小类, 800余篇文章,内容包含了熊猫烧香病毒、DDOS攻击、ARP病等热点问题的介绍及解决方案。从病毒查杀、防范、系统、数据等各方面的安全设置到黑客技术的了解、防范,涉及到了安全应用的全部领域, 由浅至深内容全面。
CCNA认证考试Pass必备
CCNA认证考试Pass必备
无线网络环境
无线网络环境
无线路由器故障处理
无线路由器故障处理
· 无线路由器故障处理
· 解析35岁技术人的价值..
· 无线重中之重:安全问题
· 无线局域网基本知识
· 家庭无线局域网
· 华为七千人主动辞职规..
· 微软出价446亿美元收购..
· 虚拟化的“赤壁之战”
· Windows Server 2008专..
· 802.11n:下一代的无线..
· 脉冲无线电uwb专题
· AIX操作系统管理应用
· 云计算时代来临
· 求职必杀技 决战面试官
· 龙芯要做中国的“奔腾”
· 2008年上半年IT技术图..
ARP攻击防范与解决方案
ARP攻击防范与解决方案
SQL Server 2008/2005全解
SQL Server 2008/2005全解
SOA 面向服务架构
SOA 面向服务架构
· SOA 面向服务架构
· SQL Server 2008/2005..
· Apache技术专题
· 三层交换技术专题
· SQL Server入门到精通
· 无线网状网(MESH)
· Windows远程桌面应用
· C#技术开发指南
· Apache技术专题
· Windows集群服务应用
· C#技术开发指南
· 文档格式标准开战 OOXM..
· 路由器设置与口令恢复
· Linux 集群技术专题
· PHP开发应用手册
· SOA 面向服务架构
ARP攻击防范与解决方案
ARP攻击防范与解决方案
SQL Server 2008/2005全解
SQL Server 2008/2005全解
SQL Server入门到精通
SQL Server入门到精通
· SQL Server入门到精通
· SQL Server 2008/2005..
· SOA 面向服务架构
· Apache技术专题
· C#技术开发指南
· 三层交换技术专题
· Apache技术专题
· C#技术开发指南
· Windows远程桌面应用
· 企业数据恢复指南
· Windows集群服务应用
· 路由器设置与口令恢复
· Linux 集群技术专题
· SOA 面向服务架构
· 了解统一威胁管理(UTM)..
· 解析35岁技术人的价值..