注释有助于以一种更高级的方式描述汇编语言指令序列

IDA 提供了几种不同类型的注释,每种注释适用于不同的目的

使用 Edit -> Comments 命令的选项,可以为反汇编代码清单中的任何一行代码添加注释

这是一个 scanf() 函数

某一行分号之后的内容都是注释

常规注释

常规注释位于现有汇编代码行的尾部

右击反汇编窗口右边空白的地方

选择 Enter comment,可以打开“Enter comment”对话框

或者使用快捷键“:”

输入一行注释

默认情况下,常规注释以蓝色显示

如果输入了多行注释,常规注释将跨越多行

每一行注释将排到反汇编窗口的右侧,并同样以分号开头,且与最第一个分号对齐

要编辑或删除一段注释,需要打开该注释的对话框“Enter comment”,进行编辑或删除

在分析阶段,IDA 插入常规注释说明为调用函数而压入的参数

只有当 IDA 拥有被调用函数的参数名称或类型信息时,才会使用常规注释

可重复注释

可重复注释一旦输入,将会自动出现在反汇编窗口中的许多位置

可重复注释的颜色也是蓝色的

如果一个程序位置引用了另一个包含可重复注释的位置,则该注释会在第一个位置回显

默认情况下,回显的注释以灰色文本显示

可重复注释的快捷键为分号“;”

右键反汇编窗口右边空白的地方

选择 Enter repeatable comment,也能进行注释

输入注释的内容,hello

点击 OK

如果在一个显示可重复注释的位置添加一段常规注释,则可重复注释将被常规注释覆盖,该位置将仅显示常规注释

任何时候,如果 IDA 自动创建一个字符串变量,字符串变量所在的位置都将添加一段虚拟的可重复注释

这种称为虚拟注释,因为用户无法编辑这段注释

虚拟注释的内容被设置为字符串变量的内容,并且会在整个数据库中显示,就像是一段可重复注释一样

任何引用字符串变量的位置都将以重复注释的形式显示字符串变量的内容

这类注释是因为引用了字符串变量才显示的

在前注释和在后注释

在前注释和在后注释是出现在指定的反汇编行之前或之后的全行注释,它们是 IDA 中仅有的不以分号为前缀的注释

通过将与某个行相关的地址与该行之后或之前的指令进行比较,即可区分“在前”注释与“在后”注释

函数注释

通过函数注释,可以为函数的反汇编代码清单顶部显示的注释分组

上图就为函数注释,其中也包含函数原型

要输入函数注释,首先应突出显示函数顶部的函数名称,然后再输入一段常规注释或可重复注释

可重复函数注释将在调用该函数的任何位置回显

IDA Pro 权威指南学习笔记(十二) - IDA 中的注释的更多相关文章

  1. IDA Pro 权威指南学习笔记(七) - 其他 IDA 显示窗口

    默认情况下 IDA 不会打开这些窗口,可通过 View -> Open Subviews 命令打开 Strings 窗口(Strings) Strings 窗口中显示的是从二进制文件中提取出的一 ...

  2. IDA Pro 权威指南学习笔记(十四) - 操纵函数

    IDA 无法定位一个函数调用,由于没有直接的方法到达函数,IDA 将无法识别它们 IDA 可能无法正确确定函数的结束部分,需要手动干预,以更正反汇编代码中的错误 如果编译器已经将函数分割到几个地址范围 ...

  3. IDA Pro 权威指南学习笔记(十) - 栈帧

    栈帧(stack frame)是在程序的运行时栈中分配的内存块,用于特定的函数调用 如果一个函数没有执行则不需要内存,当函数被调用时就需要用到内存 1.传给函数的参数的值需要存储到函数能够找到它们的位 ...

  4. IDA Pro 权威指南学习笔记(八) - 基本 IDA 导航

    导航目标 在分析阶段,IDA 会通过检查二进制文件的符号表生成符号名称,或根据二进制文件引用位置的方式自动生成一个名称 反汇编窗口中显示的任何名称都是导航目标 双击任何一个符号,IDA 将跳转到相应的 ...

  5. IDA Pro 权威指南学习笔记(一) - 启动 IDA

    启动 IDA 启动 IDA,有一个欢迎界面 之后有一个对话框 选择 New 将启动一个对话框来选择将要分析的文件 选择 Go 将使 IDA 打开一个空白的工作区 如果要选择分析的文件,可以直接拖到 I ...

  6. IDA Pro权威指南学习笔记(一)

    一直不懂逆向,最近刚好不忙,于是学习逆向,用来做笔记,顺便和大家分享交流. 参考书籍<IAD PRO权威指南> 工具: PETools: ETools 是另一款很好的PE文件编辑工具,以前 ...

  7. IDA Pro 权威指南学习笔记(二) - IDA 数据库文件

    生成数据库文件 把要分析的文件用 IDA 打开后,会生成 3 个数据库文件 扩展名分别为 .id0,id1,nam .id0 文件是一个二叉树形式的数据库 .id1 文件包含描述每个程序字节的标记 . ...

  8. IDA Pro 权威指南学习笔记(十三) - 基本代码转换

    IDA提供的代码转换包括: 1.将数据转换为代码 2.将代码转换为数据 3.指定一个指令序列为函数 4.更改现有函数的起始或结束地址 5.更改指令操作数的显示格式 代码显示选项 通过 Options ...

  9. IDA Pro 权威指南学习笔记(五) - IDA 主要的数据显示窗口

    在默认配置下,IDA(从 6.1 版开始)会在对新二进制文件的初始加载和分析阶段创建 7 个显示窗口 3 个立即可见的窗口分别为 IDA-View 窗口.函数窗口和消息输出窗口 可以通过 View - ...

随机推荐

  1. iOS开发之利用IJKPlayer+nginx+rtmp搭建直播的推流和拉流

    最近项目中想实现直播的功能,所以研究了一段时间的直播功能,当然也是在别人的基础上不断的学习实现的,所以记录一下,希望对大家有所帮助. 直播拉流功能: 这里使用了开源的IJKPlayer第三框架,ijk ...

  2. kd树 求k近邻 python 代码

      之前两篇随笔介绍了kd树的原理,并用python实现了kd树的构建和搜索,具体可以参考 kd树的原理 python kd树 搜索 代码 kd树常与knn算法联系在一起,knn算法通常要搜索k近邻, ...

  3. Buildroot 指定内核版本

    /******************************************************************************** * Buildroot 指定内核版本 ...

  4. 如何写一个LaTeX类文件,并设计你自己的简历

    2017/8/29 20:26:03 原文地址 https://www.sharelatex.com/blog/2011/03/27/how-to-write-a-latex-class-file-a ...

  5. erl_0018 erlang_看门狗001_“内存大量占用检测及解决办法”

    绪:erlang出现问题百分之六七十在于内存问题,“进程消息队列爆炸”.“进程堆栈持续增长” 工具:erlang:memory(),erlang:system_info(process_count). ...

  6. 对Json的各种遍历方法

    慎用for in函数(有可能由于原型链的问题导致遍历问题): 如果要是用for in  一定要使用if (obj1.hasOwnProperty(key)) {}先做判断 解决方法 :1.eval() ...

  7. 对于Dubbo一些面试题自己的答案

    Dubbo 头几天瞧到<Java顶尖口试必问-Dubbo口试题汇总>,对于内里得难点本人试着答复少许,有错误得请民众指正. Dubbo固然大概不革新了,可是背靠阿里得措施能力,中文报告得多 ...

  8. LOJ2323. 「清华集训 2017」小 Y 和地铁 【搜索】【思维】【好】

    LINK 思路 首先如果直接算每一个段有三个决策 左/右 上/下 跨不跨过端点 这样的复杂度是\((2^3)^{22}\),显然是无法接受的 然后考虑怎么优化这个东西 首先左右这个决策是没有意义的 因 ...

  9. WPF 绘制对齐像素的清晰显示的线条

    此前有小伙伴询问我为何他 1 像素的线条显示发虚,然后我告诉他是“像素对齐”的问题,然而他设置了各种对齐像素的属性依旧没有作用.于是我对此进行了一系列试验,对 WPF 像素对齐的各种方法进行了一次总结 ...

  10. idea Java spring 入门 demo

    根据这个 来实现 理解 https://www.cnblogs.com/xing901022/p/3963962.html 这里没有说如何导入包,现在我们用 idea 来实现 新建项目结构后 RUN ...