在我的 iOS 应用程序上,我需要解码蓝牙接收到的 Float 值,并从不同的设备(不是 iOS)获取 4 个字节,因此我需要一个“便携式”4 字节 Float 格式。目前发件人正在使用以下格式:
数据编码:0xCCBBAAAEE
- 0xEE:指数,1 个有符号字节。
- 0xCCBBAA:尾数,3 个有符号字节。
我的问题是:如何从这样的指数和尾数构造一个(ios)浮点数?
在 iOS Float 中有这样的初始化器:
public init(符号:FloatingPointSign,指数:Int,有效数:Float)
我可以轻松地从带符号的尾数中计算出符号参数,从带符号的指数中计算出 Exp 参数,但重要参数采用浮点型,但有效数参数是浮点型,而我只收到 3 字节尾数。
假设您正在遵循标准 IEEE 格式 https://en.m.wikipedia.org/wiki/Single-precision_floating-point_format#IEEE_754_single-precision_binary_floating-point_format:_binary32,看起来确实如此 - 我很难相信你的这个蓝牙设备会使用线路上的其他任何东西 - 然后尝试这个初始化程序(自 Swift 3 起可用):
init(
sign: FloatingPointSign,
exponentBitPattern: UInt,
significandBitPattern: UInt32
)
这是由以下定义的BinaryFloatingPoint https://developer.apple.com/reference/swift/binaryfloatingpoint/1849503-init协议:
传递的值如下exponentBitPattern
and significandBitPattern
以 IEEE 754 规范定义的二进制交换格式进行解释。
上面提到的IEEE 754(单精度)Float
is:
- 符号位:1位
- 指数宽度:8 位
- 有效位数精度:24 位(23 位显式存储)
这个其他Float初始化器 https://developer.apple.com/reference/swift/float/1847937-init应该也能正常工作:
init(bitPattern: UInt32)
在这两种情况下,只需注意大字节序与小字节序 https://en.wikipedia.org/wiki/Endianness#Floating_point问题,你应该没问题;)
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)