汇编-代码解释集合

本文详细介绍了汇编语言中的关键概念,包括EXTERN和GLOBAL伪操作的用法,系统调用的原理,如INT 0x80,以及数据传送指令MOV。此外,还讲解了汇编程序的伪操作,如ORG、EQU和 TIMES,并讨论了不同类型的转移指令和通用寄存器的作用。文章还涵盖了汇编程序的命令行编译和链接过程。
摘要由CSDN通过智能技术生成

【汇编代码】

extern:EXTERN 伪操作告诉编译器当前的符号不是在本源文件中定义的,而是在其他源文件中定义的,在本源文件中可能引用该符号。如果本源文件没有实际引用该符号,该符号将不会被加入到本源文件的符号表中。

global:关键字,把符号导出到其他模块中。global是extern的对立面,如果一个模块声明一个extern的符号,然后引用它,为了防止链接错误,另外某一个模块必须确实定义了该符号,然后把它声明为global。
  1.由于在bar.c中用到函数myprint(),所以要用关键字global将其导出
  2.由于用到本文件外定义的函数choose(),所以要用关键字extern声明
  3.myprint()和choose()遵循的都是C调用约定,后面的参数先入栈,并由调用者清理堆栈

equ:表达式赋值操作符,在某些时候程序中多次出现同一个表达式,为方便起见,用赋值伪操作给表达式赋予一个名字。

int 0x80:系统调用是一个软中断,中断号是0x80,它是上层应用程序与Linux系统内核进行交互通信的唯一接口。通过int 0x80,就可使用内核资源。系统调用是通过int 0x80来实现的,eax寄存器中为调用的功能号,ebx、ecx、edx、esi等等寄存器则依次为参数,exit的功能号_NR_exit为1,write(_NR_write)功能号为4,ebx为文件描述符,stdout的文件描述符为1,ecx则为buffer的内存地址,edx为buffer长度。ebx为0表示返回0。
系统调用的参数传递规则:http://blog.csdn.net/m2o2o2d/article/details/21648777

org:orihin缩写,表示起始地址,源。在汇编语言源程序的开始通常都用一条ORG伪指令来实现规定程序的起始地址。如果不用ORG规定则汇编得到的目标程序将从0000H开始。

mov:数据传送指令,把源位置一个字节、字或双字的操作数复制到目的位置。可以是立即数到通用寄存器,也可以是通用寄存器和通用寄存器、主存、段寄存器之间的互相传送。
     e.g mov  eax,050ah; 把十六进制数050a传送到通用寄存器eax中。

call:call指令不能实现短转移,除此之外与jmp指令实现转移的原理相同。
    CPU执行call指令时,进行两步操作:
    1.将当前的IP或CS和IP压入栈中;
    2.转移;

  • 4
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值