1.了解float存储结构

float存储结构请看另一篇文章http://blog.csdn.net/whzhaochao/article/details/12885875

2.float最大值

float结构如下图:
要想获得正最大值,那就令符号位为0,指数位和尾数位全为1,则应该是最大会是,最大值应该为:
1.11111111111111111111111*2^128=(2-2^-23)*2^128= 6.805646932770577*10^38
则float类型十六进制表示为:0x7fff ffff 
 以下是测试代码:
  1. void main(int argc, char* argv[])
  2. {
  3. float a=-8.25;
  4. char *p=(char*)&a;
  5. *p=0xff;
  6. *(p+1)=0xff;
  7. *(p+2)=0xff;
  8. *(p+3)=0x7f;
  9. printf("\n&a=%x",&a);
  10. printf("\na=%f",a);
  11. }

结果并不和我们想的一样,出现了1.#QNAN0,这个我也不知道为什么,知道原因的可以回复!

 
如果指数位最后一位为0,则是我们想要的结果,
我们知道float最大为(2-2^-23)*2^127= 3.4028234663852886*10^38
见float.h
  1. #define FLT_DIG         6                       /* # of decimal digits of precision */
  2. #define FLT_EPSILON     1.192092896e-07F        /* smallest such that 1.0+FLT_EPSILON != 1.0 */
  3. #define FLT_GUARD       0
  4. #define FLT_MANT_DIG    24                      /* # of bits in mantissa */
  5. #define FLT_MAX         3.402823466e+38F        /* max value */
  6. #define FLT_MAX_10_EXP  38                      /* max decimal exponent */
  7. #define FLT_MAX_EXP     128                     /* max binary exponent */
  8. #define FLT_MIN         1.175494351e-38F        /* min positive value */
  9. #define FLT_MIN_10_EXP  (-37)                   /* min decimal exponent */
  10. #define FLT_MIN_EXP     (-125)                  /* min binary exponent */
  11. #define FLT_NORMALIZE   0
  12. #define FLT_RADIX       2                       /* exponent radix */
  13. #define FLT_ROUNDS      1                       /* addition rounding: near */
当我们令指数位为:1111 1110 =254 则指数为254-127=127
尾数位全为1,则最大数为1.11111111111111111111111*2^127=(2-2^-23)*2^127=3.4028234663852886*10^38
则十六进制表示为:0x7f7f ffff

3.测试代码:

  1. void main(int argc, char* argv[])
  2. {
  3. float a=-8.25;
  4. char *p=(char*)&a;
  5. *p=0xff;
  6. *(p+1)=0xff;
  7. *(p+2)=0x7f;
  8. *(p+3)=0x7f;
  9. printf("\n&a=%x",&a);
  10. printf("\na=%f",a);
  11. }
 
我们从结果可以看出
&a=12ff44
a=340282346638528860000000000000000000000.000000
这是float的最大值

4.float正最小值

float.h中我们看到float正的最小值为 1.175494351e-38F
  1. #define FLT_MIN         1.175494351e-38F        /* min positive value */

通过了解float类型的结构我们知道如何才能获得正的最小值,要获得正的最小值,我们只要将指数位置成最小及0000 0000 则指数为0-127=-127,然后将尾数位最后一位置1,其它置0

及十六进制为0x0000 00001

5.测试代码

  1. void main(int argc, char* argv[])
  2. {
  3. float a=-8.25;
  4. char *p=(char*)&a;
  5. *p=0x01;
  6. *(p+1)=0x00;
  7. *(p+2)=0x00;
  8. *(p+3)=0x00;
  9. printf("\n&a=%x",&a);
  10. printf("\na=%e",a);
  11. }

我们得到的结果为 1.00000000 00000000 0000 01*2^-127= 5.877472454760670*10^-039,可是结果不是我们预测的!不知道为什么

 
如果将指数位置成1,测试代码如下:
  1. void main(int argc, char* argv[])
  2. {
  3. float a=-8.25;
  4. float b=0;
  5. char *p=(char*)&a;
  6. *p=0x01;
  7. *(p+1)=0x00;
  8. *(p+2)=0x80;
  9. *(p+3)=0x00;
  10. printf("\n %d ",sizeof(a));
  11. printf("\n&a=%x",&a);
  12. printf("\na=%e",a);
  13. }
 
我们看到结果为 1.0000 0000 0000 0000 0000 001*2^-126= 1.1754944909521339e-038,这是我们想要的结果!

C语言中 Float 数据结构的存储计算的更多相关文章

  1. C语言中float,double类型,在内存中的结构(存储方式)

    C语言中float,double类型,在内存中的结构(存储方式)从存储结构和算法上来讲,double和float是一样的,不一样的地方仅仅是float是32位的,double是64位的,所以doubl ...

  2. C语言中float如何存储?

    float 内存如何存储的 类型 存储位数 总位数 偏移值 (offset) 数符(S) 阶码(E) 尾数(M) 短实数(float) 1 8 23 32 127 长实数(double) 1 11 5 ...

  3. C语言中float如何存储?(转载)

    float 内存如何存储的 类型 存储位数 总位数 偏移值(offset) 数符(S) 阶码(E) 尾数(M) 短实数(float) 1 8 23 32 127 长实数(double) 1 11 52 ...

  4. c语言中float、double、long double在内存中存储方式

    存储格式中的二机制转为浮点数: 浮点型变量在计算机内存中占用4个字节(4 Byte),即32-bit,一个浮点数由2部分组成:底数m  和 指数e: 底数部分:使用2进制数来表示此浮点数的实际值: 指 ...

  5. float double 如何存储计算2 (这个写的也不错)

    目前java遵照IEEE制定的浮点数表示法来进行float,double运算.这种结构是一种科学计数法,用符号.指数和尾数来表示,底数定为2——即把一个浮点数表示为尾数乘以2的指数次方再添上符号. 我 ...

  6. 笔试题引出float数据的存储方式的深究

    笔试题: #include <iostream>#include <stdio.h>#include <string.h>#include <conio.h& ...

  7. Java语言中:float、double数据类型在内存中是如何存储的

    引用参考 https://www.cnblogs.com/chenmingjun/p/8415464.html#4291528 https://blog.csdn.net/yansmile1/arti ...

  8. Delphi中获取Unix时间戳及注意事项(c语言中time()是按格林威治时间计算的,比北京时间多了8小时)

    uses DateUtils;DateTimeToUnix(Now) 可以转换到unix时间,但是注意的是,它得到的时间比c语言中time()得到的时间大了8*60*60这是因为Now是当前时区的时间 ...

  9. 数据结构:DHUOJ 单链表ADT模板应用算法设计:长整数加法运算(使用单链表存储计算结果)

    单链表ADT模板应用算法设计:长整数加法运算(使用单链表存储计算结果) 时间限制: 1S类别: DS:线性表->线性表应用 题目描述: 输入范例: -5345646757684654765867 ...

随机推荐

  1. ashx页面返回json字符串|jQuery 的ajax处理请求的纠结问题

    纠结,整了半天的jquery的ajax请求数据. 遇到的问题: 1 ajax方法一直进入error方法里,进入到请求的.ashx页面.这个问题,我未找到是什么原因.反正我使用了一下的代码,就好了. $ ...

  2. [Windows Azure] Management REST API Reference

    Management REST API Reference 27 out of 42 rated this helpful - Rate this topic The SQL Database Man ...

  3. DIOCP开源项目-高效稳定的服务端解决方案(DIOCP + 无锁队列 + ZeroMQ + QWorkers) 出炉了

    [概述] 自从上次发布了[DIOCP开源项目-利用队列+0MQ+多进程逻辑处理,搭建稳定,高效,分布式的服务端]文章后,得到了很多朋友的支持和肯定.这加大了我的开发动力,经过几个晚上的熬夜,终于在昨天 ...

  4. 【机器学习】粗糙集(Rough Set Approach)

    粗糙集理论是一种研究不精确,不确定性知识的数学工具. 粗糙集理论的知识表达方式一般采用信息表或称为信息系统的形式,它可以表现为四元有序组K=(U,A,V,P).其中U为对象的全体,即论域:A是属性全体 ...

  5. SPSS简单使用

    当我们的调查问卷在把调查数据拿回来后,我们该做的工作就是用相关的统计软件进行处理,在此,我们以spss为处理软件,来简要说明一下问卷的处理过程,它的过程大致可分为四个过程:定义变量.数据录入.统计分析 ...

  6. eth0 eth0:1 eth0.1 的区别

    eth0 eth0:1 和eth0.1三者的关系对应于物理网卡.子网卡.虚拟VLAN网卡的关系:物理网卡:物理网卡这里指的是服务器上实际的网络接口设备,这里我服务器上双网卡,在系统中看到的2个物理网卡 ...

  7. red hat enterprise linux 6

    i386(32位):http://rhel.ieesee.net/uingei/rhel-server-6.3-i386-dvd.iso迅雷快传:http://kuai.xunlei.com/d/PF ...

  8. 基于HTML5手机登录注册表单代码

    分享一款基于HTML5手机登录注册表单代码.这是一款鼠标点击注册登录按钮弹出表单,适合移动端使用.效果图如下: 在线预览   源码下载 实现的代码. html代码: <div class=&qu ...

  9. Android TabHost的使用 顶部选项卡

    用TabHost 来实现顶部选项卡,上代码:activity_main.xml <?xml version="1.0" encoding="utf-8"? ...

  10. Linux下 jenkins 的 使用

    在上一张jenkins已经安装成功了,现在开始使用 需要先安装几个插件 选择maven项目 这里会出现错误,点进去去配置 配置JDK,这里用JDK1.8 ,不然jenkins会报错的 这里写上mave ...