`
coderplay
  • 浏览: 580045 次
  • 性别: Icon_minigender_1
  • 来自: 广州杭州
社区版块
存档分类
最新评论

Tracing和dbg

阅读更多
代码不必用特殊的标记(比如debug_info)来编译,也可以trace.

erlang:trace是最底层的BIF实现的trace功能。格式如下

erlang:trace(PidSpec,How,FlagList)

它要通过erlang:trace_pattern(MFA,MatchSpec,FlagList)来辅助输出.

MatchSpec这东西很难写,在dbg模块中可以用dbg:fun2ms,它可以把函数转成MatchSpec.

比如:
dbg:fun2ms(fun(_) -> return_trace() end).
相当于
[{'_',[],[{return_trace}]}]

 dbg:fun2ms(fun([M,N]) when N > 3 -> return_trace() end).
相当于
 [{['$1','$2'],[{'>','$2',3}],[{return_trace}]}]




代码
  1. dbg:p(Item, Flags) -> {ok, MatchDesc} | {error, term()}   
类型说明:

MatchDesc = [MatchNum]
MatchNum = {matched, node(), integer()} | {matched, node(), 0, RPCError}
RPCError = term()

Item

  • 如果Item是一个 pid(), 对应的进程会被跟踪.此进程可能是一个远程进程(在另外的一个Erlang节点上). 这个节点必须在被跟踪节点列表中. (见 n/1 and tracer/0/2/3).
  • 如果Item是一个all原子, 系统的所有进程和以后建的进程都会被跟踪.它同样对通过n/1 or tracer/0/2/3函数加入的节点有效. 
  • 如果Item是一个new原子,则现存的进程不受影响, 而后建立的进程则会被跟踪. 它同样对通过n/1 or tracer/0/2/3函数加入的节点有效. 
  • 如果Item是一个existing原子,对现存的进程有效,对后来建立的进程无效.它同样对通过n/1 or tracer/0/2/3函数加入的节点有效. 
  • 如果Item既不是all, new ,也不是existing原子, 则注册了此名称的进程会被跟踪.此进程可能是一个远程进程(在另外的一个Erlang节点上). 这个节点必须在被跟踪节点列表中. (见 n/1 and tracer/0/2/3).
  • 如果Item 是一整数,则进程 <item.1></item.1> 被跟踪
  • 如果Item是一个元组{X, Y, Z}, 则进程 <x.y.z></x.y.z>被跟踪

Flags可以是一个原子,也可以是flags列表. 

s (send)
跟踪进程发送的消息
r (receive)
跟踪进程接收的消息
m (messages)
跟踪进程接收和发送的消息
c (call)
依照系统定义的跟踪模式,来跟踪此进程关于全局函数的调用情况(见 tp/2).
p (procs)
跟踪与此进程相关的事件
sos (set on spawn)
让所有由当前被跟踪进程所创建的子进程,都继承其flags.
sol (set on link)
每当被跟踪进程链至P2时, 让P2继承其flags
sofs (set on first spawn)
sos相同,但只有第一个子进程会继承.
sofl (set on first link)
sol相同,但只会在第一次调用link/1时跟踪
all
所有flags都设上
clear
清除所有flags


erts 的Match Specification in Erlang这章详细说明了MatchSpec

to be continued...
分享到:
评论

相关推荐

    黑龙江佳木斯7342 META ONT频繁掉线故障案例分析.pdf

    LTP(Link Tracing Protocol)是一种用于跟踪ONT注册状态的协议,用于监控和诊断ONT的注册状态。 9. OLT OLT(Optical Line Terminal)是光纤接入网关,负责光纤信号的传输和接入。 10. PON PON(Passive ...

    git-rust:重新实现用锈编写的git

    9. **社区与生态系统**:Rust 生态系统丰富,拥有许多高质量的库和工具,如 `serde` 用于序列化和反序列化,`cross` 用于跨平台编译,`tracing` 用于日志和诊断,这些都可以加速 Git-rust 的开发进程。 10. **持续...

    EurekaLog_7.5.0.0_Enterprise

    4)....Added "--el_injectjcl", "--el_createjcl", and "--el_createdbg" command-line options for ecc32/emake to inject JEDI/JCL debug info, create .jdbg file, and create .dbg file (Microsoft debug format...

    Bochs - The cross platform IA-32 (x86) emulator

    - Improved verbose physical memory access tracing - BIOS - Fix MTRR configuration (prevented boot of modern Linux kernels) - Fix interrupt vectors for INT 60h-66h (reserved for user interrupt) by ...

    DeepSeek入门宝典:赋能开发者实战的高性能AI解决方案

    内容概要:本文档详细介绍了 DeepSeek 这一高效、经济的人工智能解决方案,旨在为企业端、产品端以及开发者提供深度技术支持。对于企业而言,DeepSeek 带来了显著的成本效益和生产效率提升;而对于具体的产品和服务,它增强了用户体验的质量。特别是针对开发者,文档深入浅出地讲解了如何利用 DeepSeek 实现自动化代码生成、改写等辅助开发功能,并且提供了具体的步骤指导以满足不同环境下的部署需求,包括直接通过官方API接入、本地私有化部署或借助云平台进行托管的方式。 适合人群:希望降低开发门槛,提高工作效率的软件工程师和技术团队。 使用场景及目标:开发者可以根据自身条件选择最适合自己的部署方案来整合 DeepSeek 技术,进而达到优化编码过程、减少人为错误的目的。 其他说明:文中还包括了许多实际操作的例子,如通过代码改写的实例来展示如何改进现有程序段落,还有详细的API使用指南帮助初学者快速上手DeepSeek。此外,还提供了大量外部参考资料链接以便进一步扩展知识和技能范围。

    lusted_3cd_01_0318.pdf

    lusted_3cd_01_0318

    开源AI工具下载——Cherry-Studio-1.0.1-MACOS arm64版

    Cherry Studio是一款支持多模型服务的 Windows/macOS GPT 客户端。通过与Ollama搭配,搭建个人本地AI大模型

    chromedriver-win64-136.0.7058.0.zip

    chromedriver-win64-136.0.7058.0.zip

    matlab程序代码项目案例:使用 Simulink 进行自适应 MPC 设计

    matlab程序代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!

    mellitz_3cd_01_1116.pdf

    mellitz_3cd_01_1116

    基于MATLAB的牛顿迭代法实现

    基于MATLAB的牛顿迭代法实现

    steenman_01_0908.pdf

    steenman_01_0908

    [AB PLC例程源码][MMS_047737]System Time 64Bit Interpreted AOI.zip

    AB PLC例程代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!

    stone_3ck_01a_0518.pdf

    stone_3ck_01a_0518

    [AB PLC例程源码][MMS_041473]Input Time Stamping.zip

    AB PLC例程代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!

    lusted_3cd_01_1117.pdf

    lusted_3cd_01_1117

    2010-2023年 上市公司-管理层情感语调数据.zip

    管理层情感语调,或称为管理层语调,是一个在财务与会计领域中常用的概念,特别是在分析上市公司信息披露质量时。它主要指的是管理层在上市公司文字信息披露过程中,用词所体现出的情感倾向和可理解性。 本数据复刻了《财经研究》《中南财经政法大学学报》等顶级期刊的核心解释变量的做法。情感语调对企业未来盈余和未来绩效具有较强解释力、降低会计信息误定价、为分析师预测提供增量信息,而投资者也会对管理层情感语调做出积极反应。 情感语调1=(正面词汇数量-负面词汇数量)/词汇总量;数值越大,情感倾向越偏向正面积极。 情感语调2=(正面词汇数量-负面词汇数量)/(正面词汇数量+负面词汇数量);数值越大,情感倾向越偏向正面积极。 指标 证券代码、企业代码、年份、证券简称、行业代码、行业名称、正面词汇数量、负面词汇数量、词汇总量、句子数量、文字数量、情感语调1、情感语调2。

    mellitz_3cd_02_0318.pdf

    mellitz_3cd_02_0318

    moore_01_0909.pdf

    moore_01_0909

    lusted_3ck_02a_0119.pdf

    lusted_3ck_02a_0119

Global site tag (gtag.js) - Google Analytics