zhliao2

风雨兼程,一路向北-------fpga (Keep a quiet heart study)
【转】算术移位和逻辑移位的区别

逻辑移位(不管是左移位还是右移位)   都是空缺处补0   

    
  例如:     mov   ax   ,   1100_0111_0110_1000B   
                  mov   cl   ,   3   
                  shl   ax   ,   cl                                     ;   结果     ax   =   0011_1011_0100_0000   
    
                  mov   ax   ,   1100_0111_0110_1000B   
                  mov   cl   ,   3   
                  shr   ax   ,   cl                                     ;   结果     ax   =   0001_1000_1110_1101   
    
  算术移位要保证符号位的不改变(逻辑左移位补0,   逻辑右移位看符号位)   
    
  例如:     mov   ax   ,   1100_0111_0110_1000B   
                  mov   cl   ,   3   
                  sal   ax   ,   cl                                     ;   结果     ax   =   0011_1011_0100_0000   
    
                  mov   ax   ,   1100_0111_0110_1000B   
                  mov   cl   ,   3   
                  sar   ax   ,   cl                                     ;   结果     ax   =   1111_1000_1110_1101   
    
                  mov   ax   ,   0100_0111_0110_1000B   
                  mov   cl   ,   3   
                  sar   ax   ,   cl                                     ;   结果     ax   =   0000_1000_1110_1101           
 

可以总结如下:

  算术左移同逻辑左移   
         算术右移移入的位用符号位填   
         逻辑右移移入的位用0填 

 

原文:http://feitianfashino.blog.163.com/blog/static/11857272220115172055610/

posted on 2012-03-28 18:51  zhliao  阅读(1219)  评论(0)    收藏  举报