问题答案见图片:
https://weibo.com/u/2904335594?refer_flag=0000015010_&from=feed&loc=nickname&is_all=1
我想知道第三问,即问题 C,为什么需要 3bytes 呢,7bytes 那个也没法理解,感觉自己好笨,希望大家帮忙回答一下,谢谢
1
hxndg 2018-02-06 14:54:17 +08:00
我还是很久之前看的 csapp 不是很确定这个题的答案了。
我记得 0 是立即数,你用 movq 自然就会比较长。书上应该给了具体指令不同形式的长度吧。 ps 问问题之前最好先查询一下 https://www.zhihu.com/question/53278372 |
2
lcdtyph 2018-02-06 15:05:46 +08:00
指令长度是根据手册规定推算出来的啊,amd 当然也可以把 xor 规定成 4byte 长的指令
|
3
lgqfhwy OP @hxndg 好的,谢谢你。我之前谷歌搜一直没搜到类似的。看链接里说不同指令占用不同大小,然而奇怪的是在这个题之前 csapp 这本书丝毫没提过还和指令有关,仅指出了寄存器大小,还说了指令要和寄存器大小匹配(即通过寄存器就能判断大小,而按这个规则上面我问的题则需要 8 bytes ),我再查查看看吧
|
7
feather12315 2018-02-06 16:49:22 +08:00 via Android 1
指令分为俩部分,一部分是 mov 这样的,一部分是所要操作的数据地址(术语给忘了)。
其实他想多长就多长( x86 上,最短 1byte,最长给忘了),变长指令而已,反正都会翻译成硬件信号。 具体怎么翻译,三八译码器、三态门啥的组装呗。 |
8
lgqfhwy OP @feather12315 我之前不太懂,看的 csapp 上的感觉弄的我好像理解偏了,因为 csapp 之前一直在介绍寄存器对应的长度以及不同长度还要变换一下指令(后缀),所以这个题说指令本身长度,而且书上没有说,所以把题放在介绍寄存器长度后面,就让我往寄存器上想了。
|