ptrdiff_t

< c‎ | types
定义于头文件 <stddef.h>
typedef /*implementation-defined*/ ptrdiff_t;

ptrdiff_t二个指针相减结果所拥有的有符号整数类型。

ptrdiff_t 的位宽不小于 17 。

(C99 起)

注解

ptrdiff_t 用于指针算术和数组下标,若可能使用负值。使用其他类型,如 int 的程序,可能会例如下标超过 INT_MAX 时,或若依赖 32 位模算术时失败,譬如在 64 位系统上。

只有指向同一数组元素(包括指向数组尾后一个位置)的指针可以相减。

若数组足够大(大于 PTRDIFF_MAX 个元素,但小于 SIZE_MAX 个元素),则二个指针间的距离可能无法以 ptrdiff_t 表示,这二个指针相减的结果未定义。

对于短于 PTRDIFF_MAX 的 char 数组, ptrdiff_t 表现同 size_t 的有符号对应:它能存储任何类型的数组大小,而且在大多数平台上是 intptr_t 的同义词。

示例

#include <stdio.h>
#include <stddef.h>
#include <stdint.h>
 
int main(void)
{
    const size_t N = 100;
    int numbers[N];
 
    printf("PTRDIFF_MAX = %ld\n", PTRDIFF_MAX);
    int *p1=&numbers[18], *p2=&numbers[23];
    ptrdiff_t diff = p2-p1;
    printf("p2-p1 = %td\n", diff);
 
    return 0;
}

可能的输出:

PTRDIFF_MAX = 9223372036854775807
p2-p1 = 5

引用

  • C11 standard (ISO/IEC 9899:2011):
  • 7.19 Common definitions <stddef.h> (p: 288)
  • 7.20.3 Limits of other integer types (p: 293)
  • C99 standard (ISO/IEC 9899:1999):
  • 7.17 Common definitions <stddef.h> (p: 253)
  • 7.18.3 Limits of other integer types (p: 258)
  • C89/C90 standard (ISO/IEC 9899:1990):
  • 4.1.6 Common definitions <stddef.h>

参阅

sizeof 运算符返回的无符号整数类型
(typedef)
从指定结构体类型的起始到指定成员的字节位移
(宏函数)