汇编问题,求人指点。
对于如下定义的段:namesegment...nameends如果段中的数据占N个字节,则程序加载后,该段实际占有的空间为___?参考答案是(N/16+1)*16不知道为...
对于如下定义的段:
name segment
...
name ends
如果段中的数据占N个字节,则程序加载后,该段实际占有的空间为___?
参考答案是(N/16+1)*16 不知道为什么是这样的。
解释一下为什么答案是(n/16+1)*16。 答案是对的吧。。。 展开
name segment
...
name ends
如果段中的数据占N个字节,则程序加载后,该段实际占有的空间为___?
参考答案是(N/16+1)*16 不知道为什么是这样的。
解释一下为什么答案是(n/16+1)*16。 答案是对的吧。。。 展开
3个回答
展开全部
在8086中,如果不指明某一个段的定位类型,则编译器默认为PARA。也就是说,段的起始地址位于可用的第一个节的边界处(每个节为16字节)。
举个例子,假设有如下代码:
NAME1 SEGMENT
DB 0
NAME1 ENDS
NAME2 SEGMENT
DB 0, 1
NAME2 ENDS
常规上来说,NAME1段只有一个字节,NAME2段只有两个字节,因此完全可以把NAME1和NAME2在内存中毫无间隔地顺序存储,便于节省空间,但这对编译器的要求太高了。
编译器的处理方式是将NAME1放在一个节的起始地址处,将NAME2放在另一个节的起始地址处,两个节以16字节为边界对齐。那么即使NAME1仅含一个字节,也要占用16字节存储空间。毫无疑问,上面定义的两个数据段共占用32字节的存储空间。
这里可以作一个归纳:一个段定义的字节数如果不超过16字节,则占用16字节的空间;如果大于16小于32字节,则占用32字节的空间,因此是(n/16+1)*16,对n/16取整后计算。
举个例子,假设有如下代码:
NAME1 SEGMENT
DB 0
NAME1 ENDS
NAME2 SEGMENT
DB 0, 1
NAME2 ENDS
常规上来说,NAME1段只有一个字节,NAME2段只有两个字节,因此完全可以把NAME1和NAME2在内存中毫无间隔地顺序存储,便于节省空间,但这对编译器的要求太高了。
编译器的处理方式是将NAME1放在一个节的起始地址处,将NAME2放在另一个节的起始地址处,两个节以16字节为边界对齐。那么即使NAME1仅含一个字节,也要占用16字节存储空间。毫无疑问,上面定义的两个数据段共占用32字节的存储空间。
这里可以作一个归纳:一个段定义的字节数如果不超过16字节,则占用16字节的空间;如果大于16小于32字节,则占用32字节的空间,因此是(n/16+1)*16,对n/16取整后计算。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询