补充1:IDA的脚本IDC语言
1。IDA脚本的打开与使用:
IDA脚本两种语言:IDC(IDC,本地脚本语言)和Python
2。IDC语言介绍
1。IDC变量:IDC是一种松散的语言,没有明确的类型。使用3中数据类型,整数(IDA文档使用类型名称long)、字符串、浮点值。绝大部分的操作是针对整数和字符串。
因为字符串被视为IDC中的本地数据类型。所以不需要跟踪存储一个字符串所需空间。
IDC支持局部变量,使用任何变量前需要声明变量。
引入局部变量的关键字auto,声明时可以初始化。
全局变量的关键字extern,可以在函数内或外定义,但不能声明时带初始值,首次使用分配空间,生存周期和该会话生存周期一致。
Eg:auto addr, reg, val;
2。注释:C风格注释 /**/或//
3。使用“;”分号作为语句终止符和C一样
4。IDC不支持C风格数组(IDA5.6引入分片)、指针(IDA5.6开始支持)或结构体和联合体等复杂数据结构,IDA5.6使用的是类
5。IDC表达式
IDC支持几乎所有的C中的算术运算符,包括三元运算符,但不支持复合赋值运算符(eg:+= *= >>=等)。所有整数值的操作运作为有符号数处理,所以进行右移操作需要处理符号为(& 0x7FFFFFFF)
在IDC中不需要使用字符串来复制函数(C语言中strcpy,strdup),也不需要字符串拼接函数(C语言中strcat),使用分片指定与数组类似的变量子序列。
分片使用方法:[起始索引:结束索引] 至少需要一个索引,使用分片处理IDC字符串类似数组。
Eg: auto str=”String to slice”;
auto s1,s2,s3,s4;
s1 = str[7:9] // to
s2 = str[:6] // String
s3 = str[10:] // slice
s4 = str[5] // g
6。IDC语句
所有IDC中所有简单语句均以“;”结束。switch是IDC唯一不支持的C风格复合语句。使用for循环时注意IDC不支持复合语句
Eg:auto i;
for(i = 0; i<10; i += 2){} // 不合法
for(i = 0; i<10; i = i + 2){} // 合法
IDC并不严格限制新引入的变量作用范围,所以可以在这些变量的{}外引用
Eg:
if(1){
auto x;
x = 10;
}else{
auto y;
y = 3;
}
Message(“x = %d\n”,x);
Message(“y = %d\n”,y);
结果是:x = 10, y =0;
所以在一个函数中,不能访问其他任何函数中的声明变量。
7。IDC函数
IDC仅仅在独立程序(.idc文件)中支持用户定义函数,IDC命令对话框不支持。
IDC中static关键字用于引入一个用户定义的函数,函数列表仅包含一个以“,”逗号分割的参数列表
函数的基本结构:
static my_fun(x,y,z){
auto a,b,c;
}
IDC函数两种传参方式:指传递,地址传递(使用&)
Eg:
auto q=0,r=1,s=2;
my_func(q, r, s);
my_func(q, &r, s);
函数声明不会明确是否返回值和返回值的类型,可以使用return返回值,任何隐式返回值都为0。可以将函数引用作为参数传递给另一个函数,并将函数引用作为函数结果返回。
Eg:
static getFunc(){
return Message;
}
static useFun(func,arg){
func(arg);
}
Static main(){
auto f = getFunc();
f(“hello world\n”);
usefun(f, “Print\n”);
}
8。IDC对象
IDC定义一个称为object的根类,所有类由它衍生,创建新类时支持单一继承,不使用访问说明符,所有类成员均为有效共类,类声明仅包含类成员函数声明。创建数据成员时,创建一个给数据成员赋值的赋值语句既可。
Eg:
Class ExampleClass{
ExapmleClass(x, y){
this.a = x;
this.b = y;
}
~ExampleClass(){}
foo(x){
this.a = this.a + x;
}
}
static main(){
ExampleClass ex;
auto ex = ExampleClass(1,2);
ex.foo(10);
ex.z = "string"
}
9。IDC程序
IDC程序文件基本结构:
#include <idc.idc>
static main(){
}
IDC认可以下C与处理指令
#include<文件>
#define<宏名称>[可选值]
#ifdef<名称>
#else
#endif
#undef<名称>
10。IDC错误处理
两类错误:
1。解析错误:仅报告IDC解析过程中的第一个错误。
2。运行错误:较少见,使用异常处理(try/catch)可以弥补IDC不能调试缺陷
11。IDC数据存储
IDC并不支持传统意义上的数组,IDC数组对象是稀疏数组(即不会预先分配数组空间而是按需分配)
12。关联IDC脚本热键
格式:
#include <idc.idc>
#include <my_amazing_script.idc>
static main(){
AddHotKey("z","MyAmazingFunc");
}
补充1:IDA的脚本IDC语言的更多相关文章
- IDA的脚本IDC的一个简单使用
目的:主要是想学习一下IDA的IDC的脚本的使用.这里做了一个小的测试. 这里使用的是VS2015Community来生成文件的. 一.编写测试程序: 这里先生成我们的目标数据. 然后编写测试程序.得 ...
- NDK中, 如何提高脚本式语言的可读性
原文来自安卓教程网android.662p.com,转载时请注明文章的来源:http://android.662p.com/thread-5245-1-1.html [概述] NDK开发中, ...
- 基于lua的网页脚本开发语言cgilua(转)
这里为大家介绍基于lua脚本实现的网页开发语言,cgilua 介绍 cgilua使用Lua是一个用于创建动态网页的服务器端脚本语言.纯LUA脚本和LUA页(LP)的支持,cgilua.Lua脚本是一个 ...
- shell脚本 gawk语言 综采话单 对账 字段核对
今天被分配到对账组下的字段程序的了解和修改,在 SecureCRT 下的 run.sh 是字段对账的主程序,其中run.sh文件中含有gawk的代码. 程序的主要功能为 有两个文件夹 source存的 ...
- C语言基础:指针初级(补充) 分类: iOS学习 c语言基础 2015-06-10 21:54 19人阅读 评论(0) 收藏
结构体指针:指向结构体指针的变量的指针. 结构体指针指向结构体第一个成员变量的首地址 ->: 指向操作符 定义的指针变量必须指向结构体的首地址,才可以使用 -> 访问结构体成员变量 ...
- 将PHP作为Shell脚本语言使用
我们都知道.PHP是一种非常好的动态网页开发语言(速度飞快.开发周期短--).可是仅仅有非常少数的人意识到PHP也能够非常好的作为编写Shell脚本的语言,当PHP作为编写Shell脚本的语言时,他并 ...
- [转]如何将PHP作为Shell脚本语言使用
From : http://www.linuxfly.org/post/559/ 我们都知道,PHP是一种非常好的动态网页开发语言(速度飞快,开发周期短……).但是只有很少数的人意识到PHP也可以很好 ...
- IDA IDC Tutorials: Additional Auto-Commenting
https://www.hex-rays.com/products/ida/support/tutorials/idc/autocomment.shtml This program creates a ...
- IDA-IDC脚本编写语法
1.IDA脚本编写基础 IDC是IDA内置的脚本语言,其语法与C非常相似,它是一种解释性语言. 执行方法 在IDA中按SHIFT+F2键会弹出一个对话框,把语句直接写在对话框中,点击run就可被运行. ...
随机推荐
- 微信网页分享使用了jssdk,分享图还是不显示的几个坑
坑爹的微信分享,设置图片链接必须要满足如下条件: 1. 微信分享图链接必须是绝对路径,写相对地址不行. 比如图片地址写成 './assets/images/share.jpg' 不行!!! 必须写成 ...
- Javascript报错Converting circular structure to JSON
主要是因为对象的互相引用,怎么样才能造成对象的互相引用呢? var a = {}; var b = {}; a.b = b; b.a = a; 怎么解决,反正我试了很多,最后选择深度clone thi ...
- ##xcode 文件模板自定义
xcode 文件模板自定义 在使用xcode内部模板创建C++类文件时,创建出来的头文件是.hpp结尾的,但是我想用.h结尾的, 所以就网上找了下资料看能不能自定义模板,这样还可以修改文档注释.在网上 ...
- helm repository 相关
chart repo是一个可用来存储index.yaml与打包的chart文件的HTTP server.当要分享chart时,需要上传chart文件到chart仓库,任何一个能够提供yaml与tar文 ...
- java IO流读取图片供前台显示
最近项目中需要用到IO流来读取图片以提供前台页面展示,由于以前一直是用url路径的方式进行图片展示,一听说要项目要用IO流读取图片感觉好复杂一样,但任务下达下来了,做为程序员只有选择去执行喽,于是找了 ...
- [Gamma]阶段测试报告
后端测试 我们进行了覆盖性测试,覆盖率达到77%. Beta阶段发现的Bug 项目显示的图片错误 无法使用搜索框 发布实验室项目的按钮点击无法跳转 连续点击发帖按钮可能发出多个相同的帖子 不需要点击我 ...
- pytest 学习笔记一 入门篇
前言 之前做自动化测试的时候,用的测试框架为Python自带的unittest框架,随着工作的深入,发现了另外一个框架就是pytest (官方地址文档http://www.pytest.org/en/ ...
- react-native字体react-native-vector-icons在ios下的使用
react-native字体react-native-vector-icons在ios下的使用 官网和网上有各种针对ios/android的安装和使用方法:能够使用了,基本就等于安装成功了. reac ...
- Adobe Audition cc 修改音频 --- 淡出、淡入,合并、裁剪
1.导入音频到Adobe Audition cc中支持多个音频操作 也可以使用鼠标把音频放入其中 2.淡出淡入: 红色圈中的就是淡出淡入的控制符 左手按住ctrl 或者 shift 键 右手按住鼠 ...
- JavaScript生成一个不重复的ID
/** * 生成一个用不重复的ID */ function GenNonDuplicateID():String{ } 先看看下面的几个方法 1.生成[0,1)的随机数的Math.random,例如 ...