< 返回新闻公共列表
C—数据的储存(2)
发布时间:2023-06-27 21:00:34
一、练习一下
1.例一
看过C语言学习第十五弹后我们一起来做一下下面这道例一
#include
#include int main() { unsigned int i; for (i = 9; i >= 0; i--) { printf("%u\n", i); Sleep(1000);//单位毫秒 } return 0; }
答案:死循环
解析:因为这是一个无符号int 类型的i所以当i=0再- -时,成为-1,但是无符号整形中没有符号位所以就变成了一个很大的数一直打印这个条件恒成立,所以就死循环了
2.例二
看过例一我们来做一下例二:
#include #include int main() { unsigned int i; for (i = 9; i >= 0; i--) { printf("%d\n", i); Sleep(1000);//单位毫秒 } return 0; }
答案:死循环
解析:虽然这是一个无符号整形i,但是打印的时候用的%d(打印有符号整形的),所以它是由符号位的,但有人可能要问了-1不就不满足i>=0吗?别忘了i是一个我无符号整型只不过打印用的%d但这并不影响i是一个无符号整型所以判断的时候i>=0是根据无符号数判断的
3.例三
#include int main() { char a[1000]; int i; for (i = 0; i < 1000; i++) { a[i] = -1 - i; } printf("%d", strlen(a)); return 0; }
答案:255
解析:经过循环a[i]里面存的是-1 -2 -3…-127 -128但是char 类型所以不存在-129 -130…-1000,-128减去1,就变成了127 依次往后127 126 125…3 2 1 0,这才是256个数字了,所以接着循环3 2 1 0…-128 -127-126…127 …3 2 1 0直到数组填满但是strlen是求字符串的长度,找的是\0,\0的ASCII码值是0所以到第一次为0的时候就找到了长度是255.
4.例四
#include unsigned char i = 0; int main() { for (i = 0; i <= 255; i++) { printf("hello world\n"); } return 0; }
答案:死循环
解析:
因为无符号char的范围是0~255;所以当i=255是再++不会变成256因为会发生截断再次变成0由此造成死循环。下面是256的二进制位可以看到截断后二进制是00000000所以不会出现266,条件恒成立。
二、浮点型在内存中的储存
1.浮点数
浮点数的家族包括:float, double ,long double
浮点数表示范围:float.h中定义
2.浮点数存储
(1).二进制浮点数
根据国际标准IEEE(电气和电子工程协会)754,任意一个二进制浮点数v可以表示成下面的形式:
(1). (-1)^S* M* 2^E
(2).(-1)^S表示符号位,当S=0,V为正数;当S1,为负数。M表示有效数字,大于等于1,小于2’。
(3).2^E表示指数位。
v = (-1)^ s * 2^E * M
举例来说:根据上述公式,5.5 怎么写呢?
解析:1111.1111,我们都知道二进制位每位都有权重,小数点前面的1权重是0依次往前就是0 1 2 3…;小数点后面的权重则是-1依次往后-1 -2 -3…;所以5.5的二进制可以写成101.1,小数点往前移可以写成1.011*2^2,前面的第一个2代表二进制而第二个2代表移动了两位;加上正负号,因为5.5是正数所以S=0,最终可以写成V=(-1) ^ 0 * 2 ^2 1.011.所以S=0;M=1.011;E=2
举例来说:那么5.0和-5.0怎么写呢?
解析:十进制的5.0,写成二进制是101.0,相当于1.01×2^2。那么,按照上面V的格式,可以得出S=0,M=1.01,E=2。
十进制的-5.0,写成二进制是-101.0,相当于-1.01x2^2。那么,S=1,M=1.01,E=2。
举例来说:那么5.3怎写呢?
解析:十进制的5.3 写成二进制是不能精准由后面的数凑出来所以说不能精准保存
举例来说:那么0.5怎么写呢?
十进制的0.5,写成二进制是0.1(小数点后的第一位权重是-1所以相当于2^(-1)),也就是0.5,相当于1.0*2 ^(-1)。那么,按照上面V的格式,可以得出S=0,M=1.0,E=-1。
(2).浮点数的存储规定
IEEE 754对有效数字M和指数E,还有一些特别规定。
前面说过,1
/template/Home/leiyu/PC/Static