Программирование на интерфейсы является удивительным, оно способствует ослаблению связи. Как упоминал @lassevk, очень важно использовать Inversion of Control.
Кроме того, ознакомьтесь с принципами SOLID. здесь представляет собой серию видео
. Он проходит через жесткий кодированный (сильно связанный пример), затем просматривает интерфейсы, и, наконец, переходит к инструменту IoC / DI (NInject)
Вы должны работать с целыми целыми знаками:
let bytes: [UInt8] = [255, 251]
let uInt16Value = UInt16(bytes[0]) << 8 | UInt16(bytes[1])
let uInt8Value0 = uInt16Value >> 8
let uInt8Value1 = UInt8(uInt16Value & 0x00ff)
Если вы хотите преобразовать UInt16 в битовый эквивалент Int16, вы можете сделать это с помощью определенного инициализатора:
let int16Value: Int16 = -15
let uInt16Value = UInt16(bitPattern: int16Value)
И наоборот:
let uInt16Value: UInt16 = 65000
let int16Value = Int16(bitPattern: uInt16Value)
В вашем случае:
let nv: Int16 = -15
let uNv = UInt16(bitPattern: nv)
UInt8(uNv >> 8)
UInt8(uNv & 0x00ff)
extension Int16 {
var twoBytes : [UInt8] {
let unsignedSelf = UInt16(bitPattern: self)
return [UInt8(truncatingIfNeeded: unsignedSelf >> 8),
UInt8(truncatingIfNeeded: unsignedSelf)]
}
}
var test : Int16 = -15
test.twoBytes // [255, 241]
Я бы просто сделал это:
let a = UInt8(nv >> 8 & 0x00ff) // 255
let b = UInt8(nv & 0x00ff) // 241
Вы можете использовать инициализатор init(truncatingBitPattern: Int16)
:
let nv: Int16 = -15
UInt8(truncatingBitPattern: nv >> 8) // -> 255
UInt8(truncatingBitPattern: nv) // -> 241
Int16
вUInt16
, а затем разделить на два значенияUInt8
. – mixel 28 September 2015 в 20:21