我需要形成一个20字节的数据包,并通过蓝牙将有效载荷发送到硬件外设.
这个20字节的数据包在内部分为14个数据集,每个11位,最后6位应为空字符.
因此,总计:160位(20字节)= 14(集)* 11(位)6(空字符)
11位再次分为3组,每组2位,3位和6位.然而,对于主要问题并不重要,我目前能够通过采用’Int16’来形成11位.我知道,我将进行移位操作以过滤11位.
如果我只有一个数据集,那么我应该填充除了带有空字符的前11位之外的所有20个字节,如果两个数据集除了22位之外的所有数据都应该分别为空字符.
我面临的问题是形成这个顺序160位,因为奇数位是11.我想采取’Int’并做移位(<<<)操作然后做按位OR(|)但是一个Int是64位. 目前我认为采用20的固定大小的字符数组将适合这种情况.虽然从概念上来说我认为这是最好的方式,但从程序上来说,我无法形成具有实现这一目标的所有条件的逻辑.我想我需要将所有逻辑放在一个循环中. 任何人都可以告诉它是实现这一目标的正确方法,并指导我解决它,如果这是最好的方法.或者指出任何其他方式(如果可用).
解决方法
您不需要将所有数据集打包到20字节数组中,直到最后,因此将它们保存在长度为14的Int数组中.更容易使用这种方式.当您需要将其发送到硬件时,将其转换为长度为20的UInt8数组:
struct DataPacket { var dataSets = [Int](count: 14,repeatedValue: 0) func toCArray() -> [UInt8] { var result = [UInt8](count: 20,repeatedValue: 0) var index = 0 var bitsRemaining = 8 var offset = 0 for value in self.dataSets { offset = 10 while offset >= 0 { let mask = 1 << offset let bit = ((value & mask) >> offset) << (bitsRemaining - 1) result[index] |= UInt8(bit) offset -= 1 bitsRemaining -= 1 if bitsRemaining == 0 { index += 1 bitsRemaining = 8 } } } return result } } // Usage: var packet = DataPacket() packet.dataSets[0] = 0b11111111111 packet.dataSets[1] = 0b00000000011 // etc... let arr = packet.toCArray()
有很多转移操作正在进行,所以我无法解释所有这些.通常的理想是将这些11位数据集中的每一个分配为字节,并根据需要扩展到下一个字节.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。