[Pointer]在C语言中进行float型与uint8型数组内存拷贝时出现的问题与解决

原创 2015年07月11日 00:18:37
   问题描述:出现的问题比较奇怪,使用的是win7的64位操作系统下的KeiluVision4编译器,以兼容、管理员模式运行的,编写的程序是在ARM的硬件上运行的。由于需要在板上的flash存储芯片里面存储数据,数据是以字节的方式进行存储的,现在有一个float型的数据需要存储,于是声明一个临时数组变量用来存放从flash读取的字节内存,另外float型数据也是先将其4字节内存拷贝到该数组变量中,然后逐个字节存储到flash的。但是一些常见的使用方法进行内存拷贝时都出现了问题。
   联合:首先考虑到union是各个成员共享内存的,于是可以定义一个4个元素的数组变量和一个float型变量:
union arr_to_f {
    float x;
    uint8 a[4];
}u1;
   这样,要把float型数值存储到flash中时,可以给成员u1.x=…;赋值,然后将成员内数组a的四个元素存储到flash,读取时将flash中的值读到数组a中,然后直接使用成员x的值即可。一般这样做是可以的,但是我实际使用时,出了问题,先存储到flash,然后从flash读,再显示float型数值时,始终为0。
   memcpy:使用string.h头文件中的memcpy函数,直接进行内存拷贝,memcpy原型如下:
void *memcpy(void *dest, const void *src, size_t n);
   于是使用
memcpy((uint8*)&x,&a[0],sizeof(a));
   道理是一样的,但是仍然显示的float值一直为0。
   指针操作一:另外使用了x=*(float*)&a[0];这种指针操作方式,结果还是float型数值显示一直为0。
   指针操作二:与指针操作一类型,但是反过来的意思,
for(i=0;i<4;i++){
   *((uint8 *)&x + i) = *(&a[0] + i); // 逐个字节单元进行复制
}
   使用这种方式时,一切就都正常了。
  以上问题解决的思路都是一样的,但是前面几种都没有得到正确的结果,是Keil编译器的问题?但是Keil都支持这些操作的,另外之前在32位系统上使用Keil编程用的就是memcpy的方式又是可以的,难道还是在64位系统下兼容模式使用Keil编译器仍存在某些问题?还是自己的flash驱动有问题?希望在之后的时间能发现其原因。
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

memcpy函数的使用总结void *memcpy(void *dest, const void *src, size_t n);

memcpy函数的使用总结void *memcpy(void *dest, const void *src, size_t n); 顾名思义由函数的名字以及参数就可以看出该函数的主要功能: c和c++...

内存对齐,导致char型数组指针转化为float型指针出现的问题

前阵子在做一个无线调参软件时,需要把一个float型的变量从上位机(qt平台编写)发给下位机(stm32),然后我采取的做法是将储存float变量的四个字节里面的数据通过串口以此发给下位机,然后下位机...

转:C语言中的printf用%d输出float类型数据出现或以%f输出int型数据的结果为什么是0

原文地址:C语言中的printf用%d输出float类型数据出现或以%f输出int型数据的结果为什么是0

C语言中printf用%d输出float类型数据,或以%f输出int型数据的结果

C语言中printf用%d输出float类型数据,或以%f输出int型数据的结果 IEEE754标准 单精度(32位)/双精度(64位)浮点数解码 float double 有效位数

Java中浮点型数据Float和Double进行精确计算的问题

先编译成二进制。但问 题来了,2.4的二进制表示并非是精确的2.4,反而最为接近的二进制表示是2.3999999999999999

C语言中,float在内存中的储存方式

浮点型变量在计算机内存中占用4字节(Byte),即32-bit。       遵循IEEE-754格式标准。 一个浮点数由2部分组成:底数m 和 指数e。 ±mantissa × 2exponen...
  • D_Fur
  • D_Fur
  • 2012-03-24 12:02
  • 3582

C语言中 float double在内存中的存储

C语言中,对于浮点类型的数据采用单精度类型(float)和双精度类型(double)来存储,float数据占用32bit, double数据占用 64bit,我们在声明一个变量float f= ...

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

http://www.cnblogs.com/xinjun/archive/2010/03/08/1680908.html   **********************************...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)