关于Swift如何管理内存地址我有些不了解 String(s)
String(s)
这里foo和boo是指向 相同存储位置的 2个指针。
foo
boo
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机制。
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。
String
struct
AnyObject
经过Xcode 7 GM Playground和Swift 2.0的测试。
func unsafeAddressOf(object: AnyObject) -> UnsafePointer
接受AnyObject参数,即 class 的实例。它将指针返回到用于引用的对象的存储object。
object
addressOf()不能与 struct 变量一起使用:
addressOf()
struct Foo { } var f = Foo() let a = unsafeAddressOf(f) // error: cannot invoke 'unsafeAddressOf' with an argument list of type '(Foo)'
String是struct, 但是 ,NSString当传递给需要对象的函数时,它将自动桥接到。所以
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之间的不同桥接中,进行了相同的观察(对于数组和字典)。