systemtap全局变量自动打印的原因和解决方法
浏览:1821次 出处信息
在运行stap的时候,经常会发现在脚本结束运行的时候打出了很多无预期的东西,仔细一看都是些全局变量的dump, 这个问题比较烦人.
我来演示下:
$ cat > g.stp global xyz probe begin{ xyz=2010 exit(); } CTRL+D $ sudo stap g.stp xyz=0x7da #多余的显示,其实我们只想静悄悄的结束
查看了代码和文档发现:
A global declaration may be written at the outermost level anywhere, not
within a block of code. Global variables which are written but never read will be displayed automatically at session shutdown. The translator
will infer for each its value type, and if it is used as an array, its key types. Optionally, scalar globals may be initialized with a string or
number literal. The following declaration marks variables as global.
原来只写不读的通通要打印提醒你, 知道了原因就好办了.
加多个delete把全局变量清空,就没啥好显示了:
$ diff -up g1.stp g.stp --- g1.stp 2011-03-25 13:14:37.940594540 +0800 +++ g.stp 2011-03-25 13:12:59.470450112 +0800 @@ -1,5 +1,6 @@ global xyz probe begin{ xyz=2010 +delete xyz exit(); }
建议继续学习:
- Linux下如何知道文件被那个进程写 (阅读:4959)
- 在Ubuntu上使用SystemTap (阅读:3001)
- jQuery打印插件 (阅读:2898)
- 突破systemtap脚本对资源使用的限制 (阅读:2513)
- systemtap函数调用栈信息不齐的原因和解决方法 (阅读:2233)
- 用于打印的页面设计 (阅读:1824)
- systemtap观察page_cache的使用情况 (阅读:1696)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
扫一扫订阅我的微信号:IT技术博客大学习
<< 前一篇:systemtap函数调用栈信息不齐的原因和解决方法
后一篇:突破systemtap脚本对资源使用的限制 >>
文章信息
- 作者:Yu Feng 来源: Erlang非业余研究
- 标签: systemtap 打印
- 发布时间:2011-03-27 23:50:01
建议继续学习
近3天十大热文
- [66] Go Reflect 性能
- [66] Oracle MTS模式下 进程地址与会话信
- [65] 如何拿下简短的域名
- [59] IOS安全–浅谈关于IOS加固的几种方法
- [59] android 开发入门
- [59] 图书馆的世界纪录
- [58] 【社会化设计】自我(self)部分――欢迎区
- [53] 视觉调整-设计师 vs. 逻辑
- [47] 界面设计速成
- [47] 读书笔记-壹百度:百度十年千倍的29条法则