- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我在使用 MDQuery 浏览 Swift 3 中的 Spotlight 搜索结果时遇到了问题。我希望 MDQueryGetResultAtIndex
产生一个 MDItem,在 C/Objective-C 中,这个假设有效,我可以对其调用 MDItemCopyAttribute
来探索该项目。在这里,例如,我成功地获取了找到的项目的路径名:
MDItemRef item = (MDItemRef)MDQueryGetResultAtIndex(q,i);
CFStringRef path = MDItemCopyAttribute(item,kMDItemPath);
但在 Swift 3 中,MDQueryGetResultAtIndex
返回一个 UnsafeRawPointer!
(在 C 中它是一个指向 void 的指针)。为了克服这个问题,我尝试过,例如:
if let item = MDQueryGetResultAtIndex(q, 0) {
let ptr = item.bindMemory(to: MDItem.self, capacity: 1)
let path = MDItemCopyAttribute(ptr.pointee, kMDItemPath)
}
但是那会崩溃,日志显示 ptr.pointee
是一个 NSAtom。很明显,我个人的 UnsafeRawPointer mojo 不起作用(坦率地说,我一直觉得这很困惑)。
我如何将这个 UnsafeRawPointer 转换成我可以成功调用 MDItemCopyAttribute
的东西?
备选方案
我可以通过将我的 Objective-C 代码放入一个 Objective-C 辅助对象并从 Swift 调用它来克服这个障碍;但我想编写一个纯 Swift 解决方案。
同样,我可能会重写我的代码以使用更高级别的 NSMetadataQuery,我很可能会这样做;但是我使用较低级别的 MDQueryRef 的原始 Objective-C 代码运行良好,所以现在我很好奇如何将它直接转换为 Swift。
完整代码,供那些想在家尝试的人使用:
let s = "kMDItemDisplayName == \"test\"" // you probably have one somewhere
let q = MDQueryCreate(nil, s as CFString, nil, nil)
MDQueryExecute(q, CFOptionFlags(kMDQuerySynchronous.rawValue))
let ct = MDQueryGetResultCount(q)
if ct > 0 {
if let item = MDQueryGetResultAtIndex(q, 0) {
// ...
}
}
最佳答案
代码中的问题
if let item = MDQueryGetResultAtIndex(q, 0) {
let ptr = item.bindMemory(to: MDItem.self, capacity: 1)
let path = MDItemCopyAttribute(ptr.pointee, kMDItemPath)
}
UnsafeRawPointer
被解释为一个指针MDItem
引用,然后在 ptr.pointee
中取消引用,但是原始指针是 MDItem
引用,因此它被取消引用一次太频繁了。
将原始指针转换为 MDItem
引用的“最短”方法是 unsafeBitCast
:
let item = unsafeBitCast(rawPtr, to: MDItem.self)
这是 (Objective-)C 转换的直接模拟。您还可以使用 Unmanaged
方法将原始指针转换为非托管引用并从那里到托管引用(比较 How to cast self to UnsafeMutablePointer<Void> type in swift ):
let item = Unmanaged<MDItem>.fromOpaque(rawPtr).takeUnretainedValue()
这看起来有点复杂,但也许表达了意图更清楚。后一种方法也适用于 (+1) 保留引用(使用 takeRetainedValue()
)。
独立示例:
import CoreServices
let queryString = "kMDItemContentType = com.apple.application-bundle"
if let query = MDQueryCreate(kCFAllocatorDefault, queryString as CFString, nil, nil) {
MDQueryExecute(query, CFOptionFlags(kMDQuerySynchronous.rawValue))
for i in 0..<MDQueryGetResultCount(query) {
if let rawPtr = MDQueryGetResultAtIndex(query, i) {
let item = Unmanaged<MDItem>.fromOpaque(rawPtr).takeUnretainedValue()
if let path = MDItemCopyAttribute(item, kMDItemPath) as? String {
print(path)
}
}
}
}
关于swift - Swift 3 中的 MDQueryGetResultAtIndex 和 UnsafeRawPointer,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43478800/
我只想调用C函数 static inline uint64_t wyhash(const void* key, uint64_t len, uint64_t seed) 像这样来自 Swi
谁能解释一下 UnsafeRawPointer.assumimgMemoryBound(to:) 和 UnsafeRawPointer.bindMemory(to:capacity:) 有什么区别?
我想设置n Swift 中一个对象的关联对象数量 我的理解是UnsafeRawPointer的通常模式引用是这样的... static var reference = "someRef" public
下面的代码可以在 Swift Playground 中运行: import UIKit func aaa(_ key: UnsafeRawPointer!, _ value: Any! = nil)
我正在尝试执行 https 请求,但是当我尝试匹配本地和远程 ssl 证书时,Xcode 向我显示了上述错误。我在下面附上了一张错误图片和代码,如果有任何帮助,我们将不胜感激。 下面是URLSessi
我正在尝试获取设备 token 。 首先,这个值是独一无二的吗? 我承认它是一种独特的值(value),并努力获得它。我正在按照获取设备 token 的方式看到错误。 func applica
我是 UnsafeRawPointer 的新手。正如我所得到的,我需要在我的扩展中分配不安全的内存,并将指针发送到我的应用程序,在那里必须强制转换和释放它。下面是我想要做的草图。我想从 Safari
我正在研究带位置的相机。 我正在做的是当单击捕获图像按钮时,我将所有位置信息收集在字典中并进一步将其设置在 CFDictionarySetValue 中。这是我面临的问题。 CFDictionaryS
我在使用 MDQuery 浏览 Swift 3 中的 Spotlight 搜索结果时遇到了问题。我希望 MDQueryGetResultAtIndex 产生一个 MDItem,在 C/Objectiv
这是我在以前版本的 Swift 中的可行代码: let imageOptionsDictKeys = [ kCVPixelBufferPixelFormatTypeKey, kCVPixelBuff
根据 Swift 3 中 Data 的文档,我可以使用一个初始化程序从 UnsafeRawPointer 创建 Data。我需要的实际上是相反的。我有一个数据,我想创建一个指向数据字节的 Unsafe
IOHIDDeviceSetReport 方法不接受 UnsafeRawPointer 类型方法签名是: IOHIDDeviceSetReport(, , , ##UnsafePointer#>, )
我正在将一个 swift 2.3 项目更新到 3.1,我在转换这个函数时遇到了问题,特别是在一行中。 这是数据的扩展。 public func read(offset f_offset: inout
我有一个 UITableView。当点击一个单元格时,我的应用程序会生成相关图像。图像生成是在后台线程上完成的,因为一些图像需要相当长的时间来渲染。渲染图像后,将在主线程上调用 UIImageWrit
我正在尝试传递 Data? 中包含的字节到 C 函数。 C 函数声明如下: void func(const void *buffer); 我的 Swift 看起来像: myData?.withUnsa
我们有一个跨平台图像处理库,有一个调用将 CGImageRef 作为 UnsafeRawPointer 返回,我需要将其转换为 CGImage。我知道调用在 objective-c 中使用它时的工作方
无法将 Void 类型的值(又名“()”)转换为预期的参数类型“unsafeRawPointer” 代码允许我通过触摸在屏幕上画线。我正在使用字典来允许多个用户同时绘制多条线。 就在我试图将指针存储在
我想从字符串中生成 CRC32 哈希,所以我得到了 zlib 函数 crc32。 但在 Swift 3 中,这会产生问题。 代码如下所示: func crc32HashString(_ string:
我是一名优秀的程序员,十分优秀!