方法一:
直接把float数据拆分为4个unsigned char(由于数字没法拆分,所以只能用指针的),发过去,在合并为float。
其中有两点要注意。
(1)大端存储,小端存储;如果搞错读取数据就不是你接收的数据地址(我主要使用了fpga,arm以及PC机,很有可能存储方式不同,一般可能不需要考虑)
(2)字对齐。不然就合并不成float(我先前没注意直接一个很怪异的数据)
发送端
void package_frame(const void *data) { int i; for(i=0; i<4; i++) { send_frame[i] = ((uchar *)data)[i]; } }
将float data数据拆分成uchar后存储在数组send_frame[]发送。
接收端
float exchange_data(uchar *data) { float float_data; float_data = *((float*)data); return float_data; }
将uchar *data首地址付给float_data来合并成float型数据(记得字对齐和大小端存储,不然数据不对)
其实发整数等大于1字节的数据也一样。
方法二:
读取的adc数据寄存器的值不*3.3V(或5V)除以2的N次方,直接把这个数据发到上位机,在上位机程序里再*3.3V除以2的N次方。
这样就避免了传递浮点数的麻烦。