本文主要介绍swift中的指针
swift中的指针分为两类
-
typed pointer
指定数据类型
指针,即UnsafePointer<T>
,其中T表示泛型 -
raw pointer
未指定数据类型
的指针(原生指针) ,即UnsafeRawPointer
swift与OC指针对比如下:
Swift | OC | 说明 |
---|---|---|
unsafePointer | const T * | 指针及所指向的内容都不可变 |
unsafeMutablePointer | T * | 指针及其所指向的内存内容均可变 |
unsafeRawPointer | const void * | 指针指向未知类型 |
unsafeMutableRawPointer | void * | 指针指向未知类型 |
原生指针
原生指针:是指未指定数据类型的指针,有以下说明
-
对于
指针
的内存管理
是需要手动
管理的 -
指针在使用完需要
手动释放
有以下一段原生指针的使用代码,请问运行时会发生什么?
//原生指针
//对于指针的内存管理是需要手动管理的
//定义一个未知类型的指针:本质是分配32字节大小的空间,指定对齐方式是8字节对齐
let p = UnsafeMutableRawPointer.allocate(byteCount: 32, alignment: 8)
//存储
for i in 0..<4 {
p.storeBytes(of: i + 1, as: Int.self)
}
//读取
for i in 0..<4 {
//p是当前内存的首地址,通过内存平移来获取值
let value = p.load(fromByteOffset: i * 8, as: Int.self)
print("index: \(i), value: \(value)")
}
//使用完成需要dealloc,即需要手动释放
p.deallocate()
-
通过运行发现,在读取数据时有问题,原因是因为读取时指定了每次读取的大小,但是存储是直接在8字节的
p
中存储了i+1
,即可以理解为并没有指定存储时的内存大小 -
修改:通过
advanced(by:)
指定存储时的步长
//存储
for i in 0..<4 {
//指定当前移动的步数,即i * 8
p.advanced(by: i * 8).storeBytes(of: i + 1, as: Int.self)
}
修改后的运行结果如下
type pointer
作为一个开发者,有一个学习的氛围跟一个交流圈子特别重要,这是一个我的iOS开发交流群:130 595 548,不管你是小白还是大牛都欢迎入驻 ,让我们一起进步,共同发展!(群内会免费提供一些群主收藏的免费学习书籍资料以及整理好的几百道面试题和答案文档!)
在前几篇文章中,我们获取基本数据类型的地址是通过withUnsafePointer(to: