本文主要介绍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,不管你是小白还是大牛都欢迎入驻 ,让我们一起进步,共同发展!(群内会免费提供一些群主收藏的免费学习书籍资料以及整理好的几百道面试题和答案文档!)
在前几篇文章中,我们获取基本数据类型的地址是

本文详细介绍了Swift中的原生指针和Type Pointer,包括它们的区别和使用方法。通过多个实战案例,如访问结构体实例、对象绑定到结构体内存、元组指针类型转换及withMemoryRebound的使用,深入理解指针在Swift中的工作原理和操作技巧。同时,文章强调了开发者交流学习的重要性,推荐了一个iOS开发交流群。
最低0.47元/天 解锁文章
2万+

被折叠的 条评论
为什么被折叠?



