C语言的数据类型 ---size_t/ptrdiff_t/intptr_t/uintptr_t 等等

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这个头文件中找到了这个类型的定义

                           

  1. 117   
  2. 118 #if __WORDSIZE == 64  
  3. 119 # ifndef __intptr_t_defined  
  4. 120 typedef long int        intptr_t;  
  5. 121 #  define __intptr_t_defined  
  6. 122 # endif  
  7. 123 typedef unsigned long int   uintptr_t;  
  8. 124 #else  
  9. 125 # ifndef __intptr_t_defined  
  10. 126 typedef int         intptr_t;  
  11. 127 #  define __intptr_t_defined  
  12. 128 # endif  
  13. 129 typedef unsigned int        uintptr_t;  
  14. 130 #endif  


很明显intptr_t不是指针类型,但是上边的一句注释()让人很疑惑。既然不是指针类型,但是为什么说类型是为了“void *”指针?

又查了一下在《深入分析Linux内核源码》中找到了答案,原文描述如下

尽管在混合不同数据类型时你必须小心, 有时有很好的理由这样做. 一种情况是因为内存存取, 与内核相关时是特殊的. 概念上, 尽管地址是指针, 内存管理常常使用一个无符号的整数类型更好地完成; 内核对待物理内存如同一个大数组, 并且内存地址只是一个数组索引. 进一步地, 一个指针容易解引用; 当直接处理内存存取时, 你几乎从不想以这种方式解引用. 使用一个整数类型避免了这种解引用, 因此避免了 bug. 因此, 内核中通常的内存地址常常是 unsigned long, 利用了指针和长整型一直是相同大小的这个事实, 至少在 Linux 目前支持的所有平台上.

因为其所值的原因, C99 标准定义了 intptr_t 和 uintptr_t 类型给一个可以持有一个指针值的整型变量. 但是, 这些类型几乎没在 2.6 内核中使用

你可能感兴趣的:(C,Nginx)