一尘不染

Swift,字符串和内存地址

swift

关于Swift如何管理内存地址我有些不了解 String(s)

1.参考类型

这里fooboo是指向 相同存储位置的 2个指针。

class Foo { }

let foo = Foo()
let boo = foo

unsafeAddressOf(foo) // "UnsafePointer(0x7FCD13719BE0)"
unsafeAddressOf(boo) // "UnsafePointer(0x7FCD13719BE0)"

好。

2.值类型

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)"

3.更多

另请注意,Stringstruct那个莫名其妙符合到AnyObject

经过Xcode 7 GM Playground和Swift 2.0的测试。


阅读 785

收藏
2020-07-07

共1个答案

一尘不染

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)'

Stringstruct但是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之间的不同桥接中,进行了相同的观察(对于数组和字典)。

2020-07-07