float型数据与字节数组的转化
来源:互联网 发布:淘宝消费者数据 编辑:程序博客网 时间:2024/06/03 16:55
float型数据与字节数组的转化
MCU和PC的浮点数都是基于IEEE754格式的。有4字节(float)、8字节(double)、10字节(有一些不支持)。这里以4字节(float)浮点数为例。
一、C语言
转化常见的方法有:
1、强制指针类型转换。
//转换float数据到字节数组unsigned char i;float floatVariable;unsigned char charArray[4];(unsigned char) *pdata = ((unsigned char)*)&floatVariable; //把float类型的指针强制转换为unsigned char型for(i=0;i<4;i++){ charArray[i] = *pdata++;//把相应地址中的数据保存到unsigned char数组中 }//转换字节数组到float数据float floatVariable;unsigned char i; void *pf; pf = &floatVariable; (unsigned char) * px = charArray; for(i=0;i<4;i++){*(((unsigned char)*)pf+i)=*(px+i); }
2、使用结构和联合
//定义结构和联合typedef union {struct {unsigned char low_byte; unsigned char mlow_byte; unsigned char mhigh_byte; unsigned char high_byte; }float_byte; float value;}FLAOT_UNION;
这样可以在程序中直接对各数据赋值,然后获取数据。如对float_byte中的各字节赋值,可以直接从value中获取float型数据,反之亦然。
注意,从上面的转换可以看到,对于定义的数组unsignedchar charArray[4],一般charArray[0]代表低字节,charArray[3]代表高字节。
二、c#
在c#中可以使用BitConverter类中的函数进行转换,如下:
名称
说明
GetBytes(Double)
以字节数组的形式返回指定的双精度浮点值。
GetBytes(Single)
以字节数组的形式返回指定的单精度浮点值。
ToDouble
返回由字节数组中指定位置的八个字节转换来的双精度浮点数。
ToSingle
返回由字节数组中指定位置的四个字节转换来的单精度浮点数。
BitConverter类进行基础数据类型与字节数组之间的相互转换,此类便于操作基本形式的类型。一个字节定义为一个 8位无符号整数。包含的方法如下:
名称
说明
DoubleToInt64Bits
将指定的双精度浮点数转换为 64 位有符号整数。
GetBytes(Boolean)
以字节数组的形式返回指定的布尔值。
GetBytes(Char)
以字节数组的形式返回指定的 Unicode 字符值。
GetBytes(Double)
以字节数组的形式返回指定的双精度浮点值。
GetBytes(Int16)
以字节数组的形式返回指定的 16 位有符号整数值。
GetBytes(Int32)
以字节数组的形式返回指定的 32 位有符号整数值。
GetBytes(Int64)
以字节数组的形式返回指定的 64 位有符号整数值。
GetBytes(Single)
以字节数组的形式返回指定的单精度浮点值。
GetBytes(UInt16)
以字节数组的形式返回指定的 16 位无符号整数值。
GetBytes(UInt32)
以字节数组的形式返回指定的 32 位无符号整数值。
GetBytes(UInt64)
以字节数组的形式返回指定的 64 位无符号整数值。
Int64BitsToDouble
将指定的 64 位有符号整数转换成双精度浮点数。
ToBoolean
返回由字节数组中指定位置的一个字节转换来的布尔值。
ToChar
返回由字节数组中指定位置的两个字节转换来的 Unicode 字符。
ToDouble
返回由字节数组中指定位置的八个字节转换来的双精度浮点数。
ToInt16
返回由字节数组中指定位置的两个字节转换来的 16 位有符号整数。
ToInt32
返回由字节数组中指定位置的四个字节转换来的 32 位有符号整数。
ToInt64
返回由字节数组中指定位置的八个字节转换来的 64 位有符号整数。
ToSingle
返回由字节数组中指定位置的四个字节转换来的单精度浮点数。
ToString( array<Byte []()>[])
将指定的字节数组的每个元素的数值转换为它的等效十六进制字符串表示形式。
ToString( array<Byte []()>[], Int32)
将指定的字节子数组的每个元素的数值转换为它的等效十六进制字符串表示形式。
ToString( array<Byte []()>[], Int32, Int32)
将指定的字节子数组的每个元素的数值转换为它的等效十六进制字符串表示形式。
ToUInt16
返回由字节数组中指定位置的两个字节转换来的 16 位无符号整数。
ToUInt32
返回由字节数组中指定位置的四个字节转换来的 32 位无符号整数。
ToUInt64
返回由字节数组中指定位置的八个字节转换来的 64 位无符号整数。
- float型数据与字节数组的转化
- float型数据与字节数组的转化
- float型数据与字节数组的转化
- 关于float型数据与int型,字节数组的转化
- 关于float型数据与int型,字节数组的转化
- Matlab Simulink 串口通讯之float数据到字节数组(uint8)的相互转化
- 字节数组与整数的相互转化
- java中,IEEE754标准(四字节)的字节数据和浮点数之间的转化(Float and byte[])
- Unity3D中的socket通信之八(字节数组与数据转换dll-byte int string float)
- 对象与字节数组简单转化
- float转成4字节的二进制数据
- 字符与字节的转化
- 字节数组与其他类型的转化
- C# double float int string 与 byte数组 相互转化
- C# double float int string 与 byte数组 相互转化
- C# double float int string 与 byte数组 相互转化
- C# double float int string 与 byte数组 相互转化
- String中空串与null的区别#抽取方法快捷键#字节数组转化成字符串#字符数组转化成字符串
- 如何消除vc屏幕闪烁的方法
- UVA 1421 UVAlive 4253 - Archery(二分)
- 通过在拦截器配置request对象,在前台页面显示返回的消息(1)
- 哈佛结构和冯·诺依曼结构的区别
- Conga Composor template building - Salesforce
- float型数据与字节数组的转化
- error LNK2019: 无法解析的外部符号 解决办法
- 大胆的预测:百度文库、在线博客或被微软Office在线编辑器取代
- RAC 安装错误
- Android AIDL使用详解 (转)
- android 的一些编译命令
- wget
- UIViewContentMode
- 九九乘法表