## 场景
当我们需要在内存中申请一块空间,可以使用伪指令db和dw
1 | db-->define byte 定义字节 |
如果按照以下写法:
1 | assume cs:code |
以上代码存在一个问题, 由于数据是在代码段中定义, cpu默认将数据识别为代码, 将导致数据不可用,那么解决办法为,增加入口标记:
1 | assume cs:code |
标记是为了告诉编译器代码段入口位置, 这样就能保证db数据不被识别为指令
知识点
- 如果我想定义20个0数据,有一种快捷的语法:
1 | assume cs:code |
- 数据段和栈段的定义
1 | assume cs:code |
- 分段定义
1 | assume cs:code,ds:data,ss:stack |
额外思考
事实上我们使用的段其实是一个逻辑概念,即是我们自己定义的,
再说白了,我定义一个段,我说它是数据段那它就是数据段,我说它是代码段那么它就是代码段,
它们其实都是一块连续的内存而已,至于为什么要区分为数据段和代码段,
很明显,是用来给我们编程提供方便的,即我们在自己的思想上或者说是编码习惯上规定,
数据放数据段中,代码放代码段中 。而我们在使用数据段的时候,为了方便或者说是代码的编写方便起见,
我们一般把数据段的段地址放在 DS 寄存器中,当然,如果你硬要觉得 DS 不顺眼,那你可以换个 ES 也是一样的,但是换成CS则不行,因为CS指向的数据都被当成指令进行处理,如果换成SS呢,可行,但是读取数据需要使用pop,修改数据需要使用push,如果是用DS或者ES ,可以直接使用DS:[0]这种形式进行内存数据的读写
被DS和ES指向的内存空间的数据被cpu当作数据处理,被SS指向的内存空间的数据被cpu当作是栈空间,被CS指向的内存空间的数据被cpu当作指令进行执行
看注释说明:
1 | assume cs:code,ds:data,ss:stack |
本文为作者原创 转载时请注明出处 谢谢
乱码三千 – 点滴积累 ,欢迎来到乱码三千技术博客站