使用intptr_t和uintptr_t

本文介绍了 intptr_t 和 uintptr_t 类型的用途,这两种类型能够存放指针地址,并提供了将指针转换为整数形式的方法。文章解释了 intptr_t 和 uintptr_t 的区别,并通过示例演示了如何使用 intptr_t 进行指针操作。
部署运行你感兴趣的模型镜像

intptr_t 和uintptr_t 类型用来存放指针地址。它们提供了一种可移植且安全的方法声明指针,而且和系统中使用的指针长度相同,对于把指针转化成整数形式来说很有用。

uintptr_t 是intptr_t 的无符号版本。对于大部分操作,用intptr_t 比较好。uintptr_t 不像intptr_t 那样灵活。下面的例子说明如何使用intptr_t:

int num;

intptr_t *pi = #

如果像下面那样试图把整数地址赋给uintptr_t 类型的指针,我们会得到一个语法错误:

uintptr_t *pu = #

错误看起来是这样的:

error: invalid conversion from 'int*' to

'uintptr_t* {aka unsigned int*}' [-fpermissive]

不过,用强制类型转换来赋值是可以的:

intptr_t *pi = #

uintptr_t *pu = (uintptr_t*)#

如果不转换类型,不能将uintptr_t 用于其他类型:

char c;

uintptr_t *pc = (uintptr_t*)&c;

当可移植性和安全性变得重要时,就应该使用这些类型。不过,为简单起见,我们的例子中不会使用。

避免把指针转换成整数。如果指针是64 位,整数只有4 字节时就会丢失信息。

早期的Intel 处理器采用16 位的分段架构,近指针和远指针也是相对的。今天的虚拟内存架构上就不是这样了。远指针和近指针是C 标准的扩展, 用来支持早期的Intel 处理器的分段架构。近指针一次只能寻址64 KB 的内存。远指针最多可以寻址1 MB 内存,但是比近指针慢。巨指针是规范化过的远指针,使用尽可能高的段。

您可能感兴趣的与本文相关的镜像

Kotaemon

Kotaemon

AI应用

Kotaemon 是由Cinnamon 开发的开源项目,是一个RAG UI页面,主要面向DocQA的终端用户和构建自己RAG pipeline

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值