找回密码
 注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

巢课
电巢直播8月计划
查看: 958|回复: 8
打印 上一主题 下一主题

一个关于无符号数和有符号数的问题,各路大神,有时间进来看看

[复制链接]

25

主题

95

帖子

447

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

积分
447
跳转到指定楼层
1#
发表于 2014-3-7 23:05 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

EDA365欢迎您!

您需要 登录 才可以下载或查看,没有帐号?注册

x
r e g [0:5] B a r;, n7 x* T: N2 s/ P
i n t e g e r T a b;; r" M! T- h6 E. _# j
B a r = - 4'd12/4;
3 ~% x3 M# e8 k' ~5 Y, R( KT a b = - 4'd12 /4;' V! f6 M" Y2 u
请教大家一个问题4 e: q2 u  X1 Q" c  I: `
最终bar和tab的值是多少?5 V- w  o8 X/ o( F+ ]. Z  j
Bar定义为寄存器变量,默认的是无符号型,tab定义整型,默认32位无符号型。& N6 v  w9 ~( F- q" @
书上说bar的最终结果是:61,tab的最终结果是:1073741821) ^1 ^; X+ H9 j5 Z% q0 P# ?

6 g& l; ~, W' N! R但是我总觉得bar的最终结果是13  (001101)
( i! \* e  @9 E/ I( i% [" C) Q
7 r$ _! ~0 n7 u! f请教大家,应该到底是多少呢?
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友 微信微信
收藏收藏 支持!支持! 反对!反对!

32

主题

331

帖子

334

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

积分
334
9#
发表于 2015-5-28 14:47 | 只看该作者
感謝分享~~

1

主题

72

帖子

325

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

积分
325
8#
发表于 2014-3-29 10:07 | 只看该作者
VHDL  有符号库和无符号库, 用谁是谁。 无纠结

25

主题

95

帖子

447

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

积分
447
7#
 楼主| 发表于 2014-3-26 20:44 | 只看该作者
lvsy 发表于 2014-3-17 08:35
: |3 d1 w( g4 ^& e" E( [: x对,应该是-3。
4 u5 Q; X  u' ?$ R. F6 t
谢谢,终于明白了

4

主题

43

帖子

913

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

积分
913
6#
发表于 2014-3-17 08:35 | 只看该作者
pipiliang 发表于 2014-3-14 23:41) o; B1 J1 J( \6 Z, m/ {
这么说的话,tab的值应该是-3喽?书上的那个结果是错误的?

4 I$ A$ Y5 ]8 u5 J2 ]0 m3 r对,应该是-3。

25

主题

95

帖子

447

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

积分
447
5#
 楼主| 发表于 2014-3-14 23:41 | 只看该作者
lvsy 发表于 2014-3-10 10:59
6 f7 x2 w. H% A"/"的优先级高于“-”,第二个结果是不对的。
3 R1 U* F, B3 F; a
这么说的话,tab的值应该是-3喽?书上的那个结果是错误的?

4

主题

43

帖子

913

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

积分
913
4#
发表于 2014-3-10 10:59 | 只看该作者
"/"的优先级高于“-”,第二个结果是不对的。

25

主题

95

帖子

447

积分

三级会员(30)

Rank: 3Rank: 3Rank: 3

积分
447
3#
 楼主| 发表于 2014-3-8 17:33 | 只看该作者
zgq800712 发表于 2014-3-7 23:502 C# R; O8 Y3 S7 P/ _+ m+ ~3 N
Bar 是6位的,Bar=-4‘d12/4 ,那就是-3,1 T* Y+ L1 _9 R2 w* P

8 m3 N+ ?  }: C3 `最高位是符号位

' V; u$ i5 g5 `% k7 s4 V5 R, Y另外一个也是先算的补码,因为tab是整形变量,默认32位,所以- 4'd12要先转化为32位的补码为FFFF_FFF4再进行计算,因为基数形式默认的是无符号型,所以便是:FFFF_FFF4/4=3FFF_FFFD它的十进制数就是:1073741821。这个数就是这么来的。所以我Bar的结果我总感觉不对,觉得应该是先将- 4'd12转化为6位的二进制补码110100=52,然后再除以4,结果得到的应该是13.

49

主题

670

帖子

4310

积分

五级会员(50)

Rank: 5

积分
4310
2#
发表于 2014-3-7 23:50 | 只看该作者
本帖最后由 zgq800712 于 2014-3-7 23:54 编辑
% l/ R7 w! Y% j. O/ }4 t
- C: T* X6 J- I. nBar 是6位的,Bar=-4‘d12/4 ,那就是-3,: T$ b4 a* Z/ A. w+ E
/ h$ C1 B' A" ?5 x
最高位是符号位
6 N  r7 V. _2 h/ U- Q  V* p: h10,0011 --- 原码
  R( `: U. f7 n5 w8 _' B  q, r11,1100  ----- 反码
4 j0 f' `- U% P; B- F11,1101 ------ 补码
# O: m5 j6 x! s6 U
* K% L8 b* y+ W& o/ s" n负数就是按补码来的;11,1101 是多少? 就是61
, f6 n. _0 d3 X9 W: W& J4 d# v$ w3 \6 j; C) d3 u
另外一个算的不对,我算不出来* m; x' e/ O; V' j9 r3 ]

" [; ]. k" q( E# T( l8 p: i; f
硬件工程师[原理图+PCB],电驱动方面,无刷控制器,电动工具,太阳能无刷泵,锂电保护板,仅限Altium。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

推荐内容上一条 /1 下一条

巢课

技术风云榜

关于我们|手机版|EDA365 ( 粤ICP备18020198号 )

GMT+8, 2025-4-6 10:35 , Processed in 0.062134 second(s), 33 queries , Gzip On.

深圳市墨知创新科技有限公司

地址:深圳市南山区科技生态园2栋A座805 电话:19926409050

快速回复 返回顶部 返回列表