Verilog中逻辑左移、逻辑右移、算数左移、算数右移的区别

一、逻辑移位
1.逻辑左移:
规则:无论有没有符号位(符号位:最高位1表示是负数,最高位0表示是正数。前提是需要声明该数是有符号位数。),都整体左移,同时低位补0。

A = 4'b1100;
B = 4'b0010;
A = A << 1; //结果是4'b1000

2.逻辑右移:
规则:无论有没有符号位,都是整体向右移,同时高位补0。

A = A >> 2; //结果是4'b0011

一、算数移位
1.算数左移:
规则:保留符号位不变,将其他整体左移,同时低位补0。

A = A <<< 1; //结果是4'b1000

2.算数右移:
规则:保留符号位不变,其他整体向右移,同时高位补0。

A = A >>> 1; //结果是4'b1010
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值