c语言 指针的偏移计算

简介: 指针可以进行加减运算,且只能进行加减计算,叫做指针偏移。今天我们就讲解一下什么是指针偏移。

前言


指针可以进行加减运算,且只能进行加减计算,叫做指针偏移。今天我们就讲解一下什么是指针偏移。


一、指针偏移的概述:


前面说指针的类型决定了指针的操作规则。

int *p1 指针 *p1 一次操作4字节空间,

float *p2 指针 *p2一次操作4字节空间,

double *p3 指针 *p3 一次操作8字节空间。

指针可以进行加减运算,且只能进行加减计算,叫做指针偏移。加减n ,实则加减 n 个类型大小。

如下:

p1+1 , 1为sizeof( int ) , 4

p2-2 , 2为sizeof( float ) , 8

p3+3 , 3为sizeof( double ) , 24


二、指针偏移的应用:


注:这里为了让大家更好的观察,我用了 %zd 来输出。


73ed6cb5e8f17971c384387edfe4455.png

同理:如果用了double 型的就会相差8个字节,也就是1个double 类型。

c044f1546d8e7d18e8bd40f382ac4d4.png


总结


这个知识点并不常用,大家可以稍微了解一下。

下节课讲解 数组指针。


相关文章
|
1天前
|
网络协议 C语言
C语言的函数指针数组的声明及应用场景
C语言的函数指针数组的声明及应用场景
|
2天前
|
C语言
C语言----深入理解指针(5)(一)
C语言----深入理解指针(5)
|
2天前
|
C语言
C语言---深入指针(4)(二)
C语言---深入指针(4)
11 2
|
2天前
|
C语言
C语言---深入指针(4)(一)
C语言---深入指针(4)
|
2天前
|
C语言
C语言----深入理解指针(5)(二)
C语言----深入理解指针(5)
|
2天前
|
C语言
C语言-----计算两个int(32位)整数m和n的二进制表达中,有多少个位(bit)不同?
C语言-----计算两个int(32位)整数m和n的二进制表达中,有多少个位(bit)不同?
|
2天前
|
Serverless C语言
C语言----递归函数,计算一个非负整数的数字之和
C语言----递归函数,计算一个非负整数的数字之和
11 0
|
2天前
|
C语言
C语言----关于二维数组传参的本质相关的知识点(数组指针、指针数组)
C语言----关于二维数组传参的本质相关的知识点(数组指针、指针数组)
|
2天前
|
C语言
C语言--深入指针(1)二刷
C语言--深入指针(1)二刷
|
2天前
|
C语言
C语言---试计算在区间1 到n 的所有整数中,数字x(0 ≤ x ≤ 9)共出现了多少次?
C语言---试计算在区间1 到n 的所有整数中,数字x(0 ≤ x ≤ 9)共出现了多少次?