查看: 88|回覆: 0

[Swift] swift指针及内存管理内存绑定实例详解

[複製鏈接]

6

主題

1

回帖

0

積分

热心网友

金币
1
閲讀權限
220
精華
0
威望
0
贡献
0
在線時間
0 小時
註冊時間
2008-9-17
發表於 2022-11-24 11:35:01 | 顯示全部樓層 |閲讀模式

swift API 绑定

swift提供了3种不同的API来绑定/重新绑定指针

  • assumingMemoryBound(to:)
  • bindMemory(to: capacity:)
  • withMemoryRebound(to: capacity: body:)

绕过编译器检查 - assumingMemoryBound

就是假定内存绑定

func testPointer(_ p: UnsafePointer<Int>) {
    print(p)
}
let tuple = (30, 40)
withUnsafePointer(to: tuple) { (tuplePtr: UnsafePointer<(Int, Int)>) in
    testPointer(UnsafeRawPointer(tuplePtr)
    .assumingMemoryBound(to: Int.self))
}

其实 两者本质没什么区别,都是指向内存的指针

UnsafePointer 指向1块Int内存

UnsafePointer<Int, Int> 指向一个元组tuple内存, 也就是一块连续的内存,包含连个连续的Int

两者都是首地址

一种方式就是不 强转 UnsafePointer<Int, Int> 为 UnsafePointer

  • 先把 元组指针转换成原始指针 UnsafeRawPointer(tuplePtr)
  • 原始指针调用 assumingMemoryBound 绑定成Int 指针 UnsafeRawPointer(tuplePtr).assumingMemoryBound(to: Int.self)
func testPointer(_ p: UnsafePointer<Int>) {
    print(p[0])
    print(p[1])
}
let tuple = (30, 40)
withUnsafePointer(to: tuple) { (tuplePtr: UnsafePointer<(Int, Int)>) in
    testPointer(UnsafeRawPointer(tuplePtr).assumingMemoryBound(to: Int.self))
}

结果

30

40

assumingMemoryBound的意义在于:

有时候不想做指针类型转换来增加代码的复杂度

就可以调用 此api绕过编译器检查,但是并没有发生实际的指针转换

内存转换 - bindMemory

实际发生了转换,改变当前内存指针绑定的类型

func testPointer(_ p: UnsafePointer<Int>) {
    print(p[0])
    print(p[1])
}
let tuple = (30, 40)
withUnsafePointer(to: tuple) { (tuplePtr: UnsafePointer<(Int, Int)>) in
    testPointer(UnsafeRawPointer(tuplePtr)
    .bindMemory(to: Int.self, capacity: 1))
}

结果

30

40

bindMemory - 相比于assumingMemoryBound,就是改变内存绑定类型

临时改变内存绑定 - withMemoryRebound

func testPointer(_ p: UnsafePointer<Int8>) {
    print(p)
}
let UInt8Ptr = UnsafePointer<UInt8>.init(bitPattern: 30)
UInt8Ptr?.withMemoryRebound(to: Int8.self, capacity: 1, 
	{ (Int8Ptr: UnsafePointer<Int8>) in
    testPointer(Int8Ptr)
})

结果

0x000000000000001e

withMemoryRebound意义在于:

临时改变内存绑定,出了api 尾随闭包作用域之后,绑定就不存在了

最后,补充一个小tip

也许你会对swift 闭包 函数的语法形式感觉会不习惯,编译器也会自动直接转变为函数体

其实高级语言语法习惯仅仅就是一种语法而已

底层其实是函数栈的形式

一个函数 包括 函数名(也就是方法指针),多个参数,函数体(包含多个变量与调用)

内存表达函数的方式就是栈的形式:

入栈顺序: 函数指针,参数顺序入栈,函数体内部逐行顺序入栈

按照这个逻辑,最后一个尾随闭包参数就可以直接变为函数体,这样并不影响函数栈的入栈方式

以上就是swift指针及内存管理内存绑定实例详解的详细内容,更多关于swift指针内存管理绑定的资料请关注琼殿技术社区其它相关文章!

您可能感兴趣的文章:
  • Framework中实现OC和Swift的混编方案
  • Swift设计思想Result<T>与Result<T, E: Error>类型解析
  • Swift Error重构优化详解
  • Swift Error重构的基础示例详解
  • swift内存管理指针类型使用实例详解
  • Swift使用enum抹平数组元素差异实例详解
  • swift依赖注入和依赖注入容器详解
回覆

使用道具 舉報

您需要登錄後才可以回帖 登錄 | 立即注册

本版積分規則

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.

在本版发帖返回顶部