题目:编程,将data段中的数据按如下格式写入table段中,并计算21年中的人均收入(取整),结果也按照下面的格式保存在table段中。
提示:可将data段中的数据看成是多个数组,而将table中的数据看成是一个结构型数据的数组,每个结构型数据中包含多个数据项。可用bx定位每个结构型数据,用idata定位数据项,用si定位数组项中的每一个元素,对于table中的数据的访问可采用[bx].idata和[bx].idata[si]的寻址方式。
思路:整个过程通过两个循环来完成。第一个循环是将data中的year数据、summ数据以及ne数据拷贝到table中。第二个循环是计算table中的人均收入。在第一个循环中嵌套一个小循环,该小循环的次数为4,作用是将data中的四字节数据拷贝至table,除了这个循环之外,我们还需要把data中的ne数据拷贝至table。
在第一个循环的过程,较为复杂的是对各个数据项进行定位。我们用di来定位data中year和summ的偏移,用bx来定位ne的偏移,用si来定位table中各个结构体的偏移。
assume cs:codesg,ds:datasg,es:tablesg,ss:stacksg
datasg segment
db '1975','1976','1977','1978','1979','1980','1981','1982','1983','1984','1985'
db

本文介绍了如何使用汇编语言处理结构型数据数组,将段中的数据按特定格式复制并计算21年的人均收入。通过双重循环实现数据迁移,内层循环用于复制每项数据的四个字节,外层循环处理不同结构体。同时,详细说明了如何利用地址偏移量定位各个数据项。
最低0.47元/天 解锁文章
4658

被折叠的 条评论
为什么被折叠?



