打印

C程序中嵌入汇编方法

[复制链接]
1683|6
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
hsbjb|  楼主 | 2011-7-22 09:10 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
由于C语言在定时方面的缺陷,在某些场合下,C程序中需要嵌入汇编代码,以弥补C的缺陷。通常,在C语言程序中嵌入汇编的方法,无外乎两种
在C程序中填入#asm和#endasm的编译命令,在之中填入汇编代码 编写汇编函数,通过链接定位器和特殊的编译方式链接方式加入到所有程序的目标代码中
但这两种方法都存在实现困难的问题,对刚起步经验不足的程序员来说,基本上很难弄懂和编译成功。
而我想到的办法是:将汇编代码定义成一数组,然后使C程序以代码方式运行数组。其实,这就是我们所知的蠕虫病毒的原理。
具体方法是这样的,要知道,汇编代码其实也是一常数,8位CPU中,一句代码是用8位二进制表示,16位CPU中,一句代码是用16位二进制表示,所以,以51单片机(8位)为例,其一系列的汇编程序代码,在C程序中就是一个unsigned char类型的数组。那么,我们可以把想嵌入的汇编代码在C程序中定义成一个数组:
unsigned char code huibian[n]={……};
然后的问题就是如何启动它了。
我们知道,C语言中,无返回类型函数指针的定义为
void (*name_of_function )();
另外C语言中强制类型转换为
(type)variable;
所以,基于上面两个语句,我们就可以把huibian这个数组指针(数组名就是一指针)转化为函数指针
(void(*)())huibian;
那么,既然都是函数指针了,直接运行就行了
(*(void(*)())huibian)();
这样就大功告成了。
再有,这方法的缺点就是,一开始得先把汇编代码译制成数组,这工作代码短还凑活,长了就不好办了,可以的话,编一个译码的工具程序

相关帖子

沙发
无冕之王| | 2011-7-22 14:04 | 只看该作者
讲的不错

使用特权

评论回复
板凳
gxgclg| | 2011-7-22 15:42 | 只看该作者
对汇编一直都不太熟

使用特权

评论回复
地板
mcu5i51| | 2011-7-22 19:37 | 只看该作者
复杂的时候还是建立单独的ASM文件在连接好;
asm关键字很方便,但是有些编译器不支持,也不适合复杂的操作;
LZ的数组法比以上两种更难,只适合没有任何参数和变量操作的函数;要知道变量位置是可变的,直接写二进制编码不可能预知变量分布情况,定位声明除外,不过估计没几个用C不很多变量指定地址吧

使用特权

评论回复
5
加班加点| | 2011-7-22 22:35 | 只看该作者
学习了

使用特权

评论回复
6
maoyanketi| | 2011-7-23 09:47 | 只看该作者
一直用汇编,对c语言不太熟

使用特权

评论回复
7
zhongxjb| | 2011-7-23 15:38 | 只看该作者
C语言中,无返回类型函数指针的定义为
void (*name_of_function )();
name_of_function 不应这么定义吧,
C语言中,无返回类型函数指针的定义为
void (*P )();p为一指向无返回类型函数的指针变量,而不是函数的名字

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

193

主题

2354

帖子

0

粉丝