首页 | 新闻 | 新品 | 文库 | 方案 | 视频 | 下载 | 商城 | 开发板 | 数据中心 | 座谈新版 | 培训 | 工具 | 博客 | 论坛 | 百科 | GEC | 活动 | 主题月 | 电子展
返回列表 回复 发帖

浮点数存取方法及源程序

浮点数存取方法及源程序

笔者在编制应用程序时有这样的要求:将运算的结果(浮点数)存入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);

}

}
返回列表