verilog中,-4'd12/4=1073741821,我看过很多解答,都说-3的补码是0011...1110,看成十进制就是1073741821,但我不理解,-3的补码不应该是3的补码然后高位全部取1吗?为什么第30位,31位是0?真的不理解,求请教
2条回答 默认 最新
- 树下等苹果 2022-05-06 16:37关注
计算过程是这样的:先计算-4'd12,然后再“/4”。
12=0000 0000 0000 0000 0000 0000 0000 1100
-12=1111 1111 1111 1111 1111 1111 1111 0100
-12/4等价于右移两位,高位补0。
所以-12/4=0011 1111 1111 1111 1111 1111 1111 1101,转换为十进制即1073741821本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥20 测距传感器数据手册i2c
- ¥15 RPA正常跑,cmd输入cookies跑不出来
- ¥15 求帮我调试一下freefem代码
- ¥15 matlab代码解决,怎么运行
- ¥15 R语言Rstudio突然无法启动
- ¥15 关于#matlab#的问题:提取2个图像的变量作为另外一个图像像元的移动量,计算新的位置创建新的图像并提取第二个图像的变量到新的图像
- ¥15 改算法,照着压缩包里边,参考其他代码封装的格式 写到main函数里
- ¥15 用windows做服务的同志有吗
- ¥60 求一个简单的网页(标签-安全|关键词-上传)
- ¥35 lstm时间序列共享单车预测,loss值优化,参数优化算法