16位代码段和32位代码段的区别
2009-08-09 17:50
731 查看
关于16位和32位 :涉及到寄存器的位数和段的位数。
寄存器的位数就是:8086下CPU的寄存器位数是16位的;80386下CPU的寄存器位数是32位的。
使用.8086伪指令将汇编语言编译成8086的指令;(默认)
使用.386p伪指令将汇编语言编译成80386的指令。
所以要使用32位的寄存器时,使用.386p伪指令。
而段的位数却是由段定义说明中的use16和use32这两个中的其中一个决定的。其实,汇编编译程序在将USE16或者USE16编译成机器语言的时候,就是段描述符中的第6个字节的第6位(我们一般称为D位),如果是USE16,就将该为设为0,如果是USE32,就设置为1
16位代码段最长只能为64k,段内偏移量为16位,默认的指令地址及操作地址为16位;
32位代码段最长可以4G,段内偏移量为32位,默认的指令地址及操作地址为32位。
相关资料:http://topic.csdn.net/t/20060228/17/4583935.html
寄存器的位数就是:8086下CPU的寄存器位数是16位的;80386下CPU的寄存器位数是32位的。
使用.8086伪指令将汇编语言编译成8086的指令;(默认)
使用.386p伪指令将汇编语言编译成80386的指令。
所以要使用32位的寄存器时,使用.386p伪指令。
而段的位数却是由段定义说明中的use16和use32这两个中的其中一个决定的。其实,汇编编译程序在将USE16或者USE16编译成机器语言的时候,就是段描述符中的第6个字节的第6位(我们一般称为D位),如果是USE16,就将该为设为0,如果是USE32,就设置为1
16位代码段最长只能为64k,段内偏移量为16位,默认的指令地址及操作地址为16位;
32位代码段最长可以4G,段内偏移量为32位,默认的指令地址及操作地址为32位。
相关资料:http://topic.csdn.net/t/20060228/17/4583935.html
相关文章推荐
- 16位和32位代码段的区别
- 16位代码段与32位代码段的区别
- i386汇编中16位代码段与32位代码段的区别
- 16位的MD5加密和32位MD5加密的区别
- 说说 MD5 加密后的类型(16位与 32位的区别)
- 32位代码段和16位代码段切换的实例
- 8位16位32位单片机区别
- 颜色模式中8位,16位,24位,32位色彩是什么意思?会有什么区别?计算机颜色格式( 8位 16位 24位 32位色)
- 32位代码段不能写显存吗?==里面提到怎么在汇编使用16位,32位标志
- 颜色模式中8位,16位,24位,32位色彩是什么意思?会有什么区别?计算机颜色格式( 8位 16位 24位 32位色)【转】
- 关于MD5 32位和16位的区别以及linux /etc/shadow 文件详解
- mov sreg, r/m16 在16位和32位编程中的区别
- 16位的MD5加密和32位MD5加密的区别
- 8位单片机 16位 32位区别?
- 关于16位和32位代码段
- 8位单片机 16位 32位区别?
- 16位和32位代码段
- 颜色模式中8位,16位,24位,32位色彩是什么意思?会有什么区别?计算机颜色格式( 8位 16位 24位 32位色)<转>
- 16位的MD5加密和32位MD5加密的区别
- 32位和64位系统区别及int字节数