3 回答

TA貢獻(xiàn)1797條經(jīng)驗(yàn) 獲得超4個(gè)贊
一個(gè)對(duì)象的指針(即,實(shí)例引用類型)可以被轉(zhuǎn)換為一個(gè)UnsafePointer<Void>
(的夫特映射const void *
,UnsafeRawPointer
在夫特3)和背部。在Objective-C中你會(huì)寫
void *voidPtr = (__bridge void*)self;// MyType *mySelf = (__bridge MyType *)voidPtr;
(有關(guān)這些演員陣容的確切含義,請(qǐng)參閱Clang ARC文檔中的3.2.4橋接演員表。)
Swift有一種Unmanaged
用于此目的的類型。使用起來有點(diǎn)麻煩,因?yàn)樗梢?code>COpaquePointer 代替使用UnsafePointer<Void>
。這里有兩個(gè)輔助方法(以O(shè)bjective-C __bridge
強(qiáng)制轉(zhuǎn)換命名):
func bridge<T : AnyObject>(obj : T) -> UnsafePointer<Void> { return UnsafePointer(Unmanaged.passUnretained(obj).toOpaque()) // return unsafeAddressOf(obj) // ***}func bridge<T : AnyObject>(ptr : UnsafePointer<Void>) -> T { return Unmanaged<T>.fromOpaque(COpaquePointer(ptr)).takeUnretainedValue() // return unsafeBitCast(ptr, T.self) // ***}
“復(fù)雜”表達(dá)式只是滿足Swifts嚴(yán)格類型系統(tǒng)所必需的。在編譯的代碼中,這只是指針之間的轉(zhuǎn)換。(***
如果您愿意使用“不安全”方法,可以在注釋中指示更短,但編譯后的代碼是相同的。)
使用此輔助方法,您可以將其傳遞self
給C函數(shù)
let voidPtr = bridge(self)
(或者UnsafeMutablePointer<Void>(bridge(self))
如果C函數(shù)需要一個(gè)可變指針),并將其轉(zhuǎn)換回對(duì)象指針 - 例如在回調(diào)函數(shù)中 -
let mySelf : MyType = bridge(voidPtr)
不會(huì)發(fā)生所有權(quán)轉(zhuǎn)移,因此self
只要使用了void指針,就必須確保存在。
并且為了完整起見,Swift等同于Objective-C __bridge_retained
和__bridge_transfer
func bridgeRetained<T : AnyObject>(obj : T) -> UnsafePointer<Void> { return UnsafePointer(Unmanaged.passRetained(obj).toOpaque())}func bridgeTransfer<T : AnyObject>(ptr : UnsafePointer<Void>) -> T { return Unmanaged<T>.fromOpaque(COpaquePointer(ptr)).takeRetainedValue()}
bridgeRetained()
將對(duì)象指針強(qiáng)制轉(zhuǎn)換為void指針并保留該對(duì)象。bridgeTransfer()
將void指針轉(zhuǎn)換回對(duì)象指針并使用retain。
優(yōu)點(diǎn)是在調(diào)用之間不能釋放對(duì)象,因?yàn)楸3至藦?qiáng)引用。缺點(diǎn)是調(diào)用必須適當(dāng)平衡,并且很容易導(dǎo)致保留周期。
更新Swift 3(Xcode 8):
func bridge<T : AnyObject>(obj : T) -> UnsafeRawPointer { return UnsafeRawPointer(Unmanaged.passUnretained(obj).toOpaque())}func bridge<T : AnyObject>(ptr : UnsafeRawPointer) -> T { return Unmanaged<T>.fromOpaque(ptr).takeUnretainedValue()}func bridgeRetained<T : AnyObject>(obj : T) -> UnsafeRawPointer { return UnsafeRawPointer(Unmanaged.passRetained(obj).toOpaque())}func bridgeTransfer<T : AnyObject>(ptr : UnsafeRawPointer) -> T { return Unmanaged<T>.fromOpaque(ptr).takeRetainedValue()}
對(duì)“不安全指針”的相關(guān)更改在中描述

TA貢獻(xiàn)1806條經(jīng)驗(yàn) 獲得超5個(gè)贊
在我看來,這是什么withUnsafeMutablePointer
- 將任意Swift指針轉(zhuǎn)換為C指針。所以大概你可以做到這一點(diǎn)(我沒試過,但我測(cè)試的代碼安全地工作):
var mself = self withUnsafeMutablePointer(&mself) { v in let v2 = UnsafeMutablePointer<Void>(v) myStruct.inputProcRefCon = v2}

TA貢獻(xiàn)1834條經(jīng)驗(yàn) 獲得超8個(gè)贊
func bridge<T : AnyObject>(obj : T) -> UnsafePointer<Void> {
return UnsafePointer(Unmanaged.passUnretained(obj).toOpaque())
}
func bridge<T : AnyObject>(ptr : UnsafePointer<Void>) -> T {
return Unmanaged<T>.fromOpaque(ptr).takeUnretainedValue()
}
func bridgeRetained<T : AnyObject>(obj : T) -> UnsafePointer<Void> {
return UnsafePointer( Unmanaged.passRetained(obj).toOpaque())}
func bridgeTransfer<T : AnyObject>(ptr : UnsafePointer<Void>) -> T {
return Unmanaged<T>.fromOpaque(ptr).takeRetainedValue()}
- 3 回答
- 0 關(guān)注
- 753 瀏覽
添加回答
舉報(bào)