代码是从以下博客文章中复制的:http://matthewpalmer.net/blog/2014/06/21/example-ios-keychain-swift-save-query/
我以前有这样的代码:
// Search for the keychain items
let status: OSStatus = SecItemCopyMatching(keychainQuery, &dataTypeRef)
// The following line crashes with an EXEC_BAD_ACCESS if dataTypeRef is nil
var opaque = dataTypeRef!.toOpaque()当我使用密钥链查询中的新帐户值运行上面的内容时,dataTypeRef将是nil,这将导致EXEC_BAD_ACCESS。
我试图通过检查dataTypeRef是否是nil这样来规避这个问题:
var opaque = COpaquePointer.null()
if (dataTypeRef != nil) {
opaque = dataTypeRef!.toOpaque() // This line should not be executed.
}虽然调试器显示dataTypeRef是nil,但它仍然将输入if子句和崩溃。
有人能解释一下这是怎么回事吗?我确实在目标C方面有经验,但我不知道这是怎么回事。
发布于 2014-10-27 19:06:14
据我所知,toOpaque/fromOpaque舞蹈已不再必要,您可以简单地使用可选绑定。可以使用可选链接将其与强制转换为NSData结合起来:
let status: OSStatus = SecItemCopyMatching(keychainQuery, &dataTypeRef)
if let retrievedData = dataTypeRef?.takeRetainedValue() as? NSData {
contentsOfKeychain = NSString(data: retrievedData, encoding: NSUTF8StringEncoding)
}还请注意,takeRetainedValue()是这里的正确选择,因为您“拥有”SecItemCopyMatching返回的项(它的名称中有“复制”)。
但实际上,您应该首先检查返回值:
let status: OSStatus = SecItemCopyMatching(keychainQuery, &dataTypeRef)
if status == errSecSuccess {
if let retrievedData = dataTypeRef?.takeRetainedValue() as? NSData {
contentsOfKeychain = NSString(data: retrievedData, encoding: NSUTF8StringEncoding)
}
}https://stackoverflow.com/questions/26593980
复制相似问题