首页   注册   登录
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
Coding
V2EX  ›  问与答

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

  •  
  •   lgqfhwy · 2018-02-06 14:34:53 +08:00 · 1135 次点击
    这是一个创建于 678 天前的主题,其中的信息可能已经有所发展或是发生改变。

    问题答案见图片:

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

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

    8 回复  |  直到 2018-02-06 17:22:12 +08:00
        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   2018-02-06 15:07:21 +08:00
    @hxndg 好的,谢谢你。我之前谷歌搜一直没搜到类似的。看链接里说不同指令占用不同大小,然而奇怪的是在这个题之前 csapp 这本书丝毫没提过还和指令有关,仅指出了寄存器大小,还说了指令要和寄存器大小匹配(即通过寄存器就能判断大小,而按这个规则上面我问的题则需要 8   bytes ),我再查查看看吧
        4
    lgqfhwy   2018-02-06 15:08:33 +08:00
    @lcdtyph 奇怪的是 csapp 在这个题之前一直没有说过,仅说了指令要和寄存器大小匹配,所以我才不懂
        5
    hxndg   2018-02-06 15:55:58 +08:00
    @lgqfhwy
    我记得书上是不是有附着的表格,上面是不是有数据。
        6
    lgqfhwy   2018-02-06 16:07:14 +08:00
    @hxndg 有,是寄存器的,按那张表是 8bytes
        7
    feather12315   2018-02-06 16:49:22 +08:00 via Android   ♥ 1
    指令分为俩部分,一部分是 mov 这样的,一部分是所要操作的数据地址(术语给忘了)。
    其实他想多长就多长( x86 上,最短 1byte,最长给忘了),变长指令而已,反正都会翻译成硬件信号。
    具体怎么翻译,三八译码器、三态门啥的组装呗。
        8
    lgqfhwy   2018-02-06 17:22:12 +08:00
    @feather12315 我之前不太懂,看的 csapp 上的感觉弄的我好像理解偏了,因为 csapp 之前一直在介绍寄存器对应的长度以及不同长度还要变换一下指令(后缀),所以这个题说指令本身长度,而且书上没有说,所以把题放在介绍寄存器长度后面,就让我往寄存器上想了。
    关于   ·   FAQ   ·   API   ·   我们的愿景   ·   广告投放   ·   感谢   ·   实用小工具   ·   3973 人在线   最高记录 5043   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.3 · 28ms · UTC 09:55 · PVG 17:55 · LAX 01:55 · JFK 04:55
    ♥ Do have faith in what you're doing.