C语言复习——一个有意思的使用指针形参的函数

复制代码
int sump(int * start, int * end)

{

    int total = 0;

    while(start < end)

    {

        total += *start;            //1

        start++;                   //2

    }

    return total;

}

其中,1、2两句可以合并为total += *start++;因为因为++与*运算优先级是同等的,但结合律是从右往左的,故会先进行start++,再进行*start。简单讲,指针先指向后递增,等同于*(start++)。

另外采用*start++意味着会先把指针指向位置的值加到total上,再递增指针。若采用*++start,则反过来,先递增指针的,在使用指针指向位置上的值加到total上。简单讲,指针先递增后指向。

(*start)++则表示指针指向的值进行递增。指针指向一直不变,为start的地址。变化的仅是该地址上的值。

注意,只有当start为指针变量时,才有start++这样的表达式。

另外,数组与指针是相互联系的,可以相互替换的。一维与多维均可。

复制代码
pr = arr;
arr[size] 等同于 *(pr + size)    //一维数组
arr[2][3] 等同于 *(*(pr + 2) + 3) 等同于 pr[2][3] //二维数组
相关推荐
Codebee11 分钟前
Ooder A2UI框架开源首发:构建企业级应用的全新选择
java·人工智能·全栈
程序员三明治1 小时前
【重学计网】TCP如何保证可靠传输?怎么保证可靠性?可靠传输的原理?
java·网络·后端·网络协议·tcp/ip·tcp·可靠传输
练习时长一年1 小时前
Leetcode热题100(跳跃游戏 II)
算法·leetcode·游戏
小白菜又菜7 小时前
Leetcode 3432. Count Partitions with Even Sum Difference
算法·leetcode
wuhen_n8 小时前
LeetCode -- 15. 三数之和(中等)
前端·javascript·算法·leetcode
sin_hielo8 小时前
leetcode 2483
数据结构·算法·leetcode
Nonoas8 小时前
动态代理:发布订阅的高级玩法
java·ide·intellij-idea
程序员-周李斌9 小时前
Java 死锁
java·开发语言·后端
Xの哲學9 小时前
Linux多级时间轮:高精度定时器的艺术与科学
linux·服务器·网络·算法·边缘计算
大头流矢9 小时前
归并排序与计数排序详解
数据结构·算法·排序算法