导航: 老古网老古论坛XMOS公共讨论区XMOS开源项目区单片机程序设计嵌入式系统广告区域
→浮点数的存储

* 101728: 浮点数的存储

   哈佛 
哈佛发表的帖子 

 浮点数的存储
将运算的结果(浮点数)存入eeprom中。我们知道,浮点数在c语言中是以ieee格式存储
的,一个浮点数占用四个字节,例如浮点数34.526存为(160,26,10,66)这四个数。要
将一个浮点数存入eeprom,实际上就是要存这四个数。那么如何在程序中得到一个浮点数的
组成数呢?

浮点数在存储时,是存储连续的字节中的,只要设法找到存储位置,就可以得到这些数了。
可以定义一个void的指针,将此指针指向需要存储的浮点数,然后将此指针强制转化为char
型,这样,利用指针就可以得到组成该浮点数的各个字节的值了。具体程序如下:

#define uchar unsigned char#define uint unsigned intvoid ftoc(void)

{ float a;

uchar i,*px

uchar x[4]; /*定义字符数组,准备存储浮点数的四个字节*、

void *pf;

px=x; /*px指针指向数组x*/

pf=&a; /*void 型指针指向浮点数首地址*/

a=34.526;

for(i=0;i  <4;i++)

{ *(px+i)=*((char *)pf+i); /*强制void 型指针转成char型,因为*/

} /*void型指针不能运算*/

}

如果已将数存入eeprom,要将其取出合并,方法也是一样,可参考下面的程序。

#define uchar unsigned char#define uint unsigned int

void ctof(void)

{ float a;

uchar i,*px

uchar x[4]={56,180,150,73};

void *pf;

px=x;

pf=&a;

for(i=0;i  <4;i++)

{ *((char *)pf+i)=*(px+i);

}

}



发表时间:2007年1月12日22:26:42

  
回复该帖

本主题共有 1 帖,分页:>>>>>该主题的所有内容[1]条

 *树形目录 只列出部分跟帖的标题以及简单的摘要信息 该主题的部分跟帖如下:

[上一篇帖子]:[转帖]看不到啊
[下一篇帖子]:万年历算法 万年历算法 /P P /P P 一、 阳历算法 /P P