·初学者问一个C语言的问题。

来源:百度知道 编辑:UC知道 时间:2024/09/22 01:33:15
程序如下,结构体score不是float型吗?怎么我如果取其值为60.3或78.9,只要小数点位是非5,就会出错,为什么?

#include "stdio.h"
struct stu
{ int num;
char *name;
char sex;
float score;
}student2={101,"Liu",'F',60.5},student1={102,"zhangping",'M',78.5};
void main()
{
printf("Number=%d\tName=%s\tSex=%c\tScore=%f\n",student2.num,student2.name,student2.sex,student2.score);
printf("Number=%d\tName=%s\tSex=%c\tScore=%f\n",student1.num,student1.name,student1.sex,student1.score);
}
就是把60.5和78.5改成60.3和78.9,试试.

简单地说,一个float型实数在内存中占4个字节,即32个二进制bit,从低位到高位依次叫第0位到第31位.这32位可以分为3个部分:符号位(第31位),阶码(第30位到第23位共8位),尾数(最低23位)。
1、符号位。最高位也就是第31位表示这个实数是正数还是负数,为0表示正数或0,为1表示负数.
2、阶码。第30位到第23位这8个二进制位表示该实数转化为规格化的二进制实数后的指数与127(127即所谓偏移量)之和即所谓阶码.
规格化的二进制实数的指数只能在-127----+127之间,所以,一个float型数的最大值在+2^127即+3.4*10^38,最小值在-2^127即-3.4*10^38.
3、尾数。其他最低的23位即第22位到第0位表示该实数转化为规格化的二进制实数后小数点以后的其余各位即所谓尾数.

例如,将十进制178.125表示成机器内的32个字节的二进制形式.

第一步:将128.125表示成二进制数:(178.125)(十进制数)=(10110010.001)(二进制形式);
第二步:将二进制形式的浮点实数转化为规格化的形式:(小数点向左移动7个二进制位可以得到)
10110010.001=1.0110010001*2^7 因而产生了以下三项:
符号位:该数为正数,故第31位为0,占一个二进制位.
阶码:指数为7,故其阶码为127+7=134=(10000110)(二进制),占从第30到第23共8个二进制位.
尾数为小数点后的部分, 即0110010001.因为尾数共23个二进制位,在后面补13个0,即01100100010000000000000
所以,178.125在内存中的实际表示方式为:
0 10000110 01100100010000000000000

再如,将-0.15625表示成机器内的32个字节的形式.
第一步:将-0.15625表示成二进制形式: (-0.15625)(十进制数)=(-0.00101)(二进制形式);
第二步:将二进制形式的浮点数转化为规格化的形式:(小数点向右移动3个二进制位可