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本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 用hfss做微带贴片阵列天线的时候分析设置有问题
- ¥50 我撰写的python爬虫爬不了 要爬的网址有反爬机制
- ¥15 Centos / PETSc / PETGEM
- ¥15 centos7.9 IPv6端口telnet和端口监控问题
- ¥120 计算机网络的新校区组网设计
- ¥20 完全没有学习过GAN,看了CSDN的一篇文章,里面有代码但是完全不知道如何操作
- ¥15 使用ue5插件narrative时如何切换关卡也保存叙事任务记录
- ¥20 海浪数据 南海地区海况数据,波浪数据
- ¥20 软件测试决策法疑问求解答
- ¥15 win11 23H2删除推荐的项目,支持注册表等