负数在内存中存储方式

大家平常写程序有时候使用有符号int,有时候使用无符号unsigned int,那么它们在内存中究竟怎么存放的呢?

无符号:因为没有负数,还是按照该数字存放

有符号

带符号最高位为符号位:

0:正数

1:负数

先灌输几个概念,学过通信原理的应该都知道

原码:正数是二进制本身,负数是它绝对值,加上最高位的符号位

5:0000 0000 0000 0000 0000 0000 0000 0101

-5:1000 0000 0000 0000 0000 0000 0000 0101

反码:正数的反码与原码相同,负数的反码为对该数的原码除符号位外各位取反

5:0000 0000 0000 0000 0000 0000 0000 0101

-5:1111 1111 1111 1111 1111 1111 1111 1010

补码:正数的补码与原码相同,负数的补码为对该数的原码除符号位外各位取反,然后加1

5:0000 0000 0000 0000 0000 0000 0000 0101

-5:1111 1111 1111 1111 1111 1111 1111 1011

 

所以-5在32位系统内存中保存为:0xfffffffb

 

 

浮点型数据在内存中的存储方式是按照IEEE 754标准进行存储的。IEEE 754标准规定了两种浮点数的表示方法:单精度浮点数和双精度浮点数。其中,单精度浮点数占用4个字节,双精度浮点数占用8个字节。 在IEEE 754标准中,浮点数的存储格式由三部分组成:符号、指数和尾数。其中,符号用来表示浮点数的正负,指数用来表示浮点数的数量级,尾数用来表示浮点数的精度。 具体来说,单精度浮点数的存储格式如下所示: | 31 | 30 - 23 | 22 - 0 | |----|---------|--------| | S | E | M | 其中,S表示符号,占用1个bit;E表示指数,占用8个bit;M表示尾数,占用23个bit。双精度浮点数的存储格式类似,只是指数和尾数的长度不同。 在计算机中,浮点数的存储方式是按照二进制补码进行存储的。具体来说,符号用0表示正数,用1表示负数;指数和尾数都用二进制补码表示。 举个例子,如果要将3.14这个单精度浮点数存储到计算机中,首先需要将3.14转换成二进制数。具体来说,可以使用以下方法进行转换: 3.14 = 11.0010001111...(二进制) 然后,根据IEEE 754标准的规定,将上述二进制数按照符号、指数和尾数的顺序存储到计算机中。具体来说,可以将上述二进制数转换成以下形式: | 0 | 10000000 | 10001100100011110101110 | |---|----------|------------------------| | S | E | M | 其中,符号S为0,表示正数;指数E为10000000,表示指数为128(因为E需要加上一个固定的偏移量127,才能表示实际的指数);尾数M为10001100100011110101110,表示尾数为1.5707964(因为M需要除以2的23次方,才能表示实际的尾数)。 因此,3.14这个单精度浮点数在计算机中的存储方式为: 01000000000100110010001111010111
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值