size_t/ptrdiff_t/intptr_t/uintptr_t
https://www.cnblogs.com/cai2007/p/4589602.html
指针类型、步长、内存大小
https://blog.csdn.net/Carl_0/article/details/80277978
指针的大小与什么有关
https://blog.csdn.net/qq_37375427/article/details/80040939
指针的大小到底是由谁决定?是多少?
https://www.cnblogs.com/noble/p/4144167.html
指针类型的大小
https://blog.csdn.net/liitdar/article/details/80980097
1.size_t
size_t是无符号整数类型,这是sizeof操作符结果的类型。如果设备的地址空间为32位,这就是一个32位无符号整数;如果设备的地址空间是64位,这就是一个64位无符号整数。换而言之,一个size_t类型的变量能够安全保存一个指针(唯一的例外是指向类函数的指针)。size_t通常用于loop计数器,数组索引和地址算数。
2.ptrdiff_t
ptrdiff_t是有符号整数类型,这是两个指针相减结果的类型。如果设备的地址空间为32位,这就是一个32位有符号整数;如果设备的地址空间是64位,这就是一个64位有符号整数。与size_t一样,ptrdiff_t能安全存储除类函数指针外的指针。
size_t和ptr_diff的大小总是和指针的大小一致,因此适合用来索引大数组、存储指针以及指针运算等。
3.intptr_t
有符号整数类型,它有一个性质,任何指向void的合法指针都可以转化为这个类型,然后还可以再转换回指向void的指针,其结果与原指针比较是相等的。
4.uintptr_t
无符号整数类型,它有一个性质,任何指向void的合法指针都可以转化为这个类型,然后还可以再转换回指向void的指针,其结果与原指针比较是相等的。
//-----------------second---part---------------------------------/
linux下定义有intptr_t ,但其不是指针类型
http://blog.sina.com.cn/s/blog_7dc67d520101mi20.html
在linux的头文件中查找这个类型的定义,在/usr/include/stdint.h这个头文件中找到了这个类型的定义
- 117
- 118 #if __WORDSIZE == 64
- 119 # ifndef __intptr_t_defined
- 120 typedef long int intptr_t;
- 121 # define __intptr_t_defined
- 122 # endif
- 123 typedef unsigned long int uintptr_t;
- 124 #else
- 125 # ifndef __intptr_t_defined
- 126 typedef int intptr_t;
- 127 # define __intptr_t_defined
- 128 # endif
- 129 typedef unsigned int uintptr_t;
- 130 #endif
很明显intptr_t不是指针类型,但是上边的一句注释()让人很疑惑。既然不是指针类型,但是为什么说类型是为了“void *”指针?
又查了一下在《深入分析Linux内核源码》中找到了答案,原文描述如下:
尽管在混合不同数据类型时你必须小心, 有时有很好的理由这样做. 一种情况是因为内存存取, 与内核相关时是特殊的. 概念上, 尽管地址是指针, 内存管理常常使用一个无符号的整数类型更好地完成; 内核对待物理内存如同一个大数组, 并且内存地址只是一个数组索引. 进一步地, 一个指针容易解引用; 当直接处理内存存取时, 你几乎从不想以这种方式解引用. 使用一个整数类型避免了这种解引用, 因此避免了 bug. 因此, 内核中通常的内存地址常常是 unsigned long, 利用了指针和长整型一直是相同大小的这个事实, 至少在 Linux 目前支持的所有平台上.
因为其所值的原因, C99 标准定义了 intptr_t 和 uintptr_t 类型给一个可以持有一个指针值的整型变量. 但是, 这些类型几乎没在 2.6 内核中使用