C语言中 Float 数据结构的存储计算
1.了解float存储结构
2.float最大值
- void main(int argc, char* argv[])
- {
- float a=-8.25;
- char *p=(char*)&a;
- *p=0xff;
- *(p+1)=0xff;
- *(p+2)=0xff;
- *(p+3)=0x7f;
- printf("\n&a=%x",&a);
- printf("\na=%f",a);
- }
结果并不和我们想的一样,出现了1.#QNAN0,这个我也不知道为什么,知道原因的可以回复!
- #define FLT_DIG 6 /* # of decimal digits of precision */
- #define FLT_EPSILON 1.192092896e-07F /* smallest such that 1.0+FLT_EPSILON != 1.0 */
- #define FLT_GUARD 0
- #define FLT_MANT_DIG 24 /* # of bits in mantissa */
- #define FLT_MAX 3.402823466e+38F /* max value */
- #define FLT_MAX_10_EXP 38 /* max decimal exponent */
- #define FLT_MAX_EXP 128 /* max binary exponent */
- #define FLT_MIN 1.175494351e-38F /* min positive value */
- #define FLT_MIN_10_EXP (-37) /* min decimal exponent */
- #define FLT_MIN_EXP (-125) /* min binary exponent */
- #define FLT_NORMALIZE 0
- #define FLT_RADIX 2 /* exponent radix */
- #define FLT_ROUNDS 1 /* addition rounding: near */
3.测试代码:
- void main(int argc, char* argv[])
- {
- float a=-8.25;
- char *p=(char*)&a;
- *p=0xff;
- *(p+1)=0xff;
- *(p+2)=0x7f;
- *(p+3)=0x7f;
- printf("\n&a=%x",&a);
- printf("\na=%f",a);
- }
a=340282346638528860000000000000000000000.000000
4.float正最小值
- #define FLT_MIN 1.175494351e-38F /* min positive value */
通过了解float类型的结构我们知道如何才能获得正的最小值,要获得正的最小值,我们只要将指数位置成最小及0000 0000 则指数为0-127=-127,然后将尾数位最后一位置1,其它置0
5.测试代码
- void main(int argc, char* argv[])
- {
- float a=-8.25;
- char *p=(char*)&a;
- *p=0x01;
- *(p+1)=0x00;
- *(p+2)=0x00;
- *(p+3)=0x00;
- printf("\n&a=%x",&a);
- printf("\na=%e",a);
- }
我们得到的结果为 1.00000000 00000000 0000 01*2^-127= 5.877472454760670*10^-039,可是结果不是我们预测的!不知道为什么
- void main(int argc, char* argv[])
- {
- float a=-8.25;
- float b=0;
- char *p=(char*)&a;
- *p=0x01;
- *(p+1)=0x00;
- *(p+2)=0x80;
- *(p+3)=0x00;
- printf("\n %d ",sizeof(a));
- printf("\n&a=%x",&a);
- printf("\na=%e",a);
- }
C语言中 Float 数据结构的存储计算的更多相关文章
- C语言中float,double类型,在内存中的结构(存储方式)
C语言中float,double类型,在内存中的结构(存储方式)从存储结构和算法上来讲,double和float是一样的,不一样的地方仅仅是float是32位的,double是64位的,所以doubl ...
- C语言中float如何存储?
float 内存如何存储的 类型 存储位数 总位数 偏移值 (offset) 数符(S) 阶码(E) 尾数(M) 短实数(float) 1 8 23 32 127 长实数(double) 1 11 5 ...
- C语言中float如何存储?(转载)
float 内存如何存储的 类型 存储位数 总位数 偏移值(offset) 数符(S) 阶码(E) 尾数(M) 短实数(float) 1 8 23 32 127 长实数(double) 1 11 52 ...
- c语言中float、double、long double在内存中存储方式
存储格式中的二机制转为浮点数: 浮点型变量在计算机内存中占用4个字节(4 Byte),即32-bit,一个浮点数由2部分组成:底数m 和 指数e: 底数部分:使用2进制数来表示此浮点数的实际值: 指 ...
- float double 如何存储计算2 (这个写的也不错)
目前java遵照IEEE制定的浮点数表示法来进行float,double运算.这种结构是一种科学计数法,用符号.指数和尾数来表示,底数定为2——即把一个浮点数表示为尾数乘以2的指数次方再添上符号. 我 ...
- 笔试题引出float数据的存储方式的深究
笔试题: #include <iostream>#include <stdio.h>#include <string.h>#include <conio.h& ...
- Java语言中:float、double数据类型在内存中是如何存储的
引用参考 https://www.cnblogs.com/chenmingjun/p/8415464.html#4291528 https://blog.csdn.net/yansmile1/arti ...
- Delphi中获取Unix时间戳及注意事项(c语言中time()是按格林威治时间计算的,比北京时间多了8小时)
uses DateUtils;DateTimeToUnix(Now) 可以转换到unix时间,但是注意的是,它得到的时间比c语言中time()得到的时间大了8*60*60这是因为Now是当前时区的时间 ...
- 数据结构:DHUOJ 单链表ADT模板应用算法设计:长整数加法运算(使用单链表存储计算结果)
单链表ADT模板应用算法设计:长整数加法运算(使用单链表存储计算结果) 时间限制: 1S类别: DS:线性表->线性表应用 题目描述: 输入范例: -5345646757684654765867 ...
随机推荐
- [Windows Azure] Administering your Windows Azure AD tenant
Administering your Windows Azure AD tenant 19 out of 20 rated this helpful - Rate this topic Publish ...
- C++11 类型推导auto
在C++11之前,auto关键字用来指定存储期.在新标准中,它的功能变为类型推断.auto现在成了一个类型的占位符,通知编译器去根据初始化代码推断所声明变量的真实类型.使用auto会拖慢c++效率吗? ...
- jsonrpc使用
jsonrpc使用 1.什么是rpc RPC(Remote Procedure Call)远程过程调用,简单说就是通过网络请求服务,不需要了解底层网络技术的协议. 常用语分布式应用程序. 2.rpc数 ...
- [转] lua 获取本地当月天数
亲测,无误. 原文传送门:lua 获取本地当月天数 开发中有用到,记录一下. local year,month = os.date("%Y", os.time()), os.dat ...
- 【Java】Java复习笔记-第二部分
类和对象 类:主观抽象,是对象的模板,可以实例化对象 习惯上类的定义格式: package xxx; import xxx; public class Xxxx { 属性 ······; 构造器 ·· ...
- Node和Electron开发入门(四):操作PC端文件系统
一.调用PC端默认方式打开本地文件 在main.js里 // 打开系统本地文件或者网页链接 const {shell} = require('electron'); // Open a local f ...
- HP管理工具System Management Homepage安装配置
如果用HP的启动光盘进行系统安装时,HP SMH 及相关组件会自动安装完成,但如果是用操作系统光盘进行系统安装,则HP SMH相关组件需要手动进行安装及相关设置!HP SMH由三部分组成:HP Sys ...
- CISCO、H3C、华为三层交换机端口二三层切换命令对比
很多人都在问H3C是否有像CISCO三层端口切换类似的命令 switchport . 答案是肯定的.有.很多人都不知道. 其实无论是思科还是H3C还是华为他们都有这样的命令.但是在H3C和华为中不经常 ...
- asp.net mvc之TempData、ViewData、ViewBag
★ViewData和ViewBag:生命周期相同,仅对当前View有效,不同的是ViewBag的类型不是字典的键值对结构,而是dynamic动态类型. ViewData ViewBag Key/Val ...
- iOS import导入时没有提示的解决办法
我认为是工程中在import时检测不到第三方类库的原因,从而import不会自动补全.在网上搜了很多,终于在stackoverflow找到了解决方法:只要把pods目录添加到用户头文件检索的路径即可. ...