微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在Swift中使用位操作?

我需要形成一个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] 举报,一经查实,本站将立刻删除。

相关推荐