68 指针的减法操作

前言

这是一个 老生常谈的问题

就是 两个结构体Person指针, p1, p2, 指向的是 虚拟内存中相邻的两个结构体对象

然后 p2 -- p1 的值得到的是 1, 而不是 sizeof(struct Person)

然后 我们来看一下 这里的编译之后的是一个实现

测试用例

这里 我们通过调节 field03 来调整 Person 结构体的占用空间

并参照 两份编译之后的 结果

复制代码
#include<stdio.h>

typedef struct Person {
    int age;
    int height;
//    int field03;
} Person;

int main(int argc, char **argv) {

    struct Person list[10], *p1, *p2;

    list[0].age = 12;
    list[2].age = 22;

    p1 = &list[0];
    p2 = &list[2];

    int delta = (int) (p2 - p1);
    printf(" the delta : %d \n", delta);

    return 0;

}

sizeof( P erson) 为 8

我们来看一下 0x00000000004005DF 的位置的相关系列代码

对应于业务代码中的 "int delta = (int) (p2 - p1);"

获取了 p2指针 和 p1指针, 然后做减法, 然后右移了3位, 等价于 /8, 然后将结果为 delta

看一下 运行时的状态

sizeof( P erson) 为 12

我们来看一下 0x00000000004005E5 的位置的相关系列代码

对应于业务代码中的 "int delta = (int) (p2 - p1);"

获取了 p2指针 和 p1指针, 然后做减法, 然后右移了2位, 等价于 /4

然后又乘以了一个 0xaaaaaaaaaaaaaaab, 等价于 / 3

因此最终是将 p2指针 和 p1指针 的地址之差 除以了 12

可以大致得出的规律 是结构体指针的减法是 两者地址只差, 还要除以 sizeof(struct Type)

看一下 运行时的状态

关于 / 3 的实现的一个测试用例

关于规范

这个在 c/c++ 相关规范中能够找到具体的说明

Arithmetic operators - cppreference.com

相关推荐
AI进化营-智能译站3 分钟前
ROS2 C++开发系列11-VS Code一键生成Doxygen注释|让ROS2节点文档自动跟上代码迭代
java·数据库·c++·ai
zhouwy1131 小时前
Linux文件系统与IO编程
linux·c++
王老师青少年编程9 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮10 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
样例过了就是过了11 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
谭欣辰11 小时前
C++ 排列组合完整指南
开发语言·c++·算法
橙子也要努力变强12 小时前
信号捕捉底层机制-机理篇2
linux·服务器·c++
盐焗鹌鹑蛋12 小时前
【C++】stack和queue类
c++
郝学胜-神的一滴13 小时前
罗德里格斯旋转公式(Rodrigues‘ Rotation Formula)完整推导
c++·unity·godot·图形渲染·three.js·unreal
lzh2004091913 小时前
深入理解进程:从PCB内核结构到写时拷贝的底层实战
linux·c++