(1)>>>(算术右移)与>>(逻辑右移)的区别:
(2)<<:(左移位运算符) >>:(右移位运算符)
在Verilog HDL中有两种移位运算符。
<<:(左移位运算符) >>:(右移位运算符)
(3)实现循环移位
(4)
算术左移和逻辑左移一样都是右边补0:
比如 00
算术左移一位:0
逻辑左移一位:0
对于二进制的数值来说左移n位等于原来的数值乘以2的n次方
比如00011010十进制是26,左移两位后是01101000转成十进制是104恰好是26的4倍。
ps:这种倍数关系只适用于左移后被舍弃的高位不含1的情况,否则会溢出。
逻辑右移很简单,只要将二进制数整体右移,左边补0即可
如逻辑右移一位为0
算术右移符号位要一起移动,并且在左边补上符号位,也就是如果符号位是1就补1符号位是0就补0
比如:11100算术右移一位为11110(符号位1跟着一起移动并且左边补了1)
对于二进制的数值来说右移n位等于原来的数值除以2的n次方
比如十进制是76(需要先将这个补码转换成原码之后再转换成十进制),右移两位后是转成十进制是19恰好是76的4倍。
文章来源: reborn.blog.csdn.net,作者:李锐博恩,版权归原作者所有,如需转载,请联系作者。
原文链接:reborn.blog.csdn.net/article/details/
版权声明:
本文来源网络,所有图片文章版权属于原作者,如有侵权,联系删除。
本文网址:https://www.mushiming.com/mjsbk/11468.html