Swift,字符串和内存地址
关于Swift如何管理内存地址我有些不了解 String(s)
回答:
这里foo
和boo
是指向 2个指针。
class Foo { }let foo = Foo()
let boo = foo
unsafeAddressOf(foo) // "UnsafePointer(0x7FCD13719BE0)"
unsafeAddressOf(boo) // "UnsafePointer(0x7FCD13719BE0)"
好。
回答:
let word0 = "hello"let word1 = word0
现在word0
和现在word1
都涉及value types
到该copy on write
机制。
[…]但是,Swift仅在绝对必要时才在幕后执行实际复制。Swift会管理所有值复制以确保最佳性能,因此,您不应避免分配以试图抢占该优化。https://developer.apple.com/library/ios/documentation/Swift/Conceptual/Swift_Programming_Language/ClassesAndStructures.html#//apple_ref/doc/uid/TP40014097-CH13-XID_134
那么为什么它们有2个不同的内存地址呢?
unsafeAddressOf(word0) // "UnsafePointer(0x7FCD1342ACE0)"unsafeAddressOf(word1) // "UnsafePointer(0x7FCD13414260)"
回答:
另请注意,String
是struct
那个莫名其妙符合到AnyObject
。
经过Xcode 7 GM Playground和Swift 2.0的测试。
回答:
func unsafeAddressOf(object: AnyObject) -> UnsafePointer
接受AnyObject
参数,即 class 的实例。它将指针返回到用于引用的对象的存储object
。
addressOf()
不能与 struct 变量一起使用:
struct Foo { }var f = Foo()
let a = unsafeAddressOf(f)
// error: cannot invoke 'unsafeAddressOf' with an argument list of type '(Foo)'
String
是struct
, 但是 ,NSString
当传递给需要对象的函数时,它将自动桥接到。所以
let word0 = "hello"let p1 = unsafeAddressOf(word0)
实际执行
let p1 = unsafeAddressOf(word0 as NSString)
您获得的不是word0
变量的地址,而是指向桥接NSString
对象的内存位置的指针。
似乎无法NSString
对在相同的Swift字符串上重复执行此桥接是否返回相同的对象(或更笼统地说,相同的Foundation对象)做出任何假设。在操场上,甚至
let word0 = "hello"let p1 = unsafeAddressOf(word0)
let p2 = unsafeAddressOf(word0)
let p3 = unsafeAddressOf(word0)
返回三个不同的地址(但在已编译项目中为相同的地址)。在Array和Dictionary之间的不同桥接中,进行了相同的观察(对于数组和字典)。
以上是 Swift,字符串和内存地址 的全部内容, 来源链接: utcz.com/qa/428729.html