首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在LC3中使用迭代进行右移

在LC3中使用迭代进行右移
EN

Stack Overflow用户
提问于 2012-10-05 12:09:14
回答 2查看 2.4K关注 0票数 0

所以我正在用LC3编写一个程序,我在屏蔽方面遇到了问题。我可以创建一个合适长度的所有1的掩码,可以很好地将所有内容移动到适当的字段,但一旦完成AND比较,我就不能再将内容移回右边。如何在LC3中右移?我在迭代比较中看到了一些东西,但我不知道如何比较不同位置的位,而为了比较相同位置的位,我最终必须将一个位向右移动。我是不是遗漏了什么?

EN

回答 2

Stack Overflow用户

发布于 2012-10-16 19:22:55

要模拟右移位,您只需制作两个掩码,一个用于源位,一个用于目标位:

代码语言:javascript
复制
src_mask=0x04;  // read from bit position 2 
dst_mask=0x01;  // write to bit position 0

while(src) {  // or while src_mask, because that too will eventually go to zero
   if (src & src_mask) dst+=dst_mask;  // or dst|=dst_mask
   src &= (~src_mask);
   dst_mask=dst_mask+dst_mask;
   src_mask=src_mask+src_mask;
}
票数 0
EN

Stack Overflow用户

发布于 2012-10-18 02:23:45

在这种情况下,您可能根本不需要进行右移位--只需在左移之前保存开始字段,然后从内存中恢复它即可。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12739337

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档