csapp:为什么需要 3bytes 和 7bytes?

2018-02-06 14:34:53 +08:00
 lgqfhwy

问题答案见图片:

https://weibo.com/u/2904335594?refer_flag=0000015010_&from=feed&loc=nickname&is_all=1

我想知道第三问,即问题 C,为什么需要 3bytes 呢,7bytes 那个也没法理解,感觉自己好笨,希望大家帮忙回答一下,谢谢

1738 次点击
所在节点    问与答
8 条回复
hxndg
2018-02-06 14:54:17 +08:00
我还是很久之前看的 csapp 不是很确定这个题的答案了。
我记得 0 是立即数,你用 movq 自然就会比较长。书上应该给了具体指令不同形式的长度吧。

ps  问问题之前最好先查询一下
https://www.zhihu.com/question/53278372
lcdtyph
2018-02-06 15:05:46 +08:00
指令长度是根据手册规定推算出来的啊,amd 当然也可以把 xor 规定成 4byte 长的指令
lgqfhwy
2018-02-06 15:07:21 +08:00
@hxndg 好的,谢谢你。我之前谷歌搜一直没搜到类似的。看链接里说不同指令占用不同大小,然而奇怪的是在这个题之前 csapp 这本书丝毫没提过还和指令有关,仅指出了寄存器大小,还说了指令要和寄存器大小匹配(即通过寄存器就能判断大小,而按这个规则上面我问的题则需要 8   bytes ),我再查查看看吧
lgqfhwy
2018-02-06 15:08:33 +08:00
@lcdtyph 奇怪的是 csapp 在这个题之前一直没有说过,仅说了指令要和寄存器大小匹配,所以我才不懂
hxndg
2018-02-06 15:55:58 +08:00
@lgqfhwy
我记得书上是不是有附着的表格,上面是不是有数据。
lgqfhwy
2018-02-06 16:07:14 +08:00
@hxndg 有,是寄存器的,按那张表是 8bytes
feather12315
2018-02-06 16:49:22 +08:00
指令分为俩部分,一部分是 mov 这样的,一部分是所要操作的数据地址(术语给忘了)。
其实他想多长就多长( x86 上,最短 1byte,最长给忘了),变长指令而已,反正都会翻译成硬件信号。
具体怎么翻译,三八译码器、三态门啥的组装呗。
lgqfhwy
2018-02-06 17:22:12 +08:00
@feather12315 我之前不太懂,看的 csapp 上的感觉弄的我好像理解偏了,因为 csapp 之前一直在介绍寄存器对应的长度以及不同长度还要变换一下指令(后缀),所以这个题说指令本身长度,而且书上没有说,所以把题放在介绍寄存器长度后面,就让我往寄存器上想了。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/428907

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX