Objective-C和Swift工作之间的桥梁:
import Foundationimport CoreFoundationimport Glibcfunc wantsNsstring(_ string: Nsstring) { print(string)}let string = "Hello,world!"wantsNsstring(string._brIDgetoObjectiveC())
但我无法弄清楚如何桥接到CoreFoundation.我不能只将Nsstring传递给想要CFString的函数:
import Foundationimport CoreFoundationimport Glibcfunc wantsCFString(_ string: CFString) { print(string)}let string = "Hello,world!"wantsCFString(string._brIDgetoObjectiveC()) //error: cannot convert value of type 'String._ObjectType' (aka 'Nsstring') to expected argument type 'CFString'
我不能像在macOS上一样:
import Foundationimport CoreFoundationimport Glibcfunc wantsCFString(_ string: CFString) { print(string)}let string = "Hello,world!"wantsCFString(string._brIDgetoObjectiveC() as CFString)//error: 'String._ObjectType' (aka 'Nsstring') is not convertible to 'CFString'; dID you mean to use 'as!' to force downcast?
用作!像错误消息建议编译但导致运行时崩溃(非法指令),并作为?产生错误:
error: conditional downcast to CoreFoundation type 'CFString' will always succeed
Bridging.swift
具有用于在NS和CF类型之间进行转换的协议,并且许多类型具有初始化器和属性,但这些都是内部或私有的.我可以使用CFStringCreateWithCString,但这需要与其他类对一起工作,如inputStream和CFReadStream.
我在这里遗漏了什么,或者在linux上真的没有办法在Foundation和CoreFoundation类型之间进行转换?
解决方法 看起来我可以将unsafeBitCast Nsstring发送到CFString:import Foundationimport CoreFoundationimport Glibcfunc wantsCFString(_ string: CFString) { print(string)}let string = "Hello,world!"wantsCFString(unsafeBitCast(string._brIDgetoObjectiveC(),to: CFString.self)//prints "Hello,world!"
这是有道理的,因为CoreFoundation和Foundation类型被设计为具有相同的内存布局 – 这就是免费桥接工作的原因.我有点惊讶它虽然适用于Swift的Foundation实现.
总结以上是内存溢出为你收集整理的在Linux上桥接到CoreFoundation或从CoreFoundation桥接全部内容,希望文章能够帮你解决在Linux上桥接到CoreFoundation或从CoreFoundation桥接所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)