C語言中6組指針和自增運算符結(jié)合方式的運算順序問題
在C語言中,當(dāng)指針運算符和++或者–結(jié)合時很容易分不清運算順序,在這里總結(jié)一下,下面一共分析6中組合: * p++,(* p)++,* (p++),++* p,++( * p), * (++p)。
先看段代碼以及輸出:
#include<stdio.h>
int main()
{
int a[3]={1,3,5};
int *p=a;
printf("----------------1----------------\n");
printf("%d\n",*p++);
printf("%d\n",*p);
int i;
for(i=0;i<3;i++)
printf("%d ",a[i]);
printf("\n");
printf("----------------2----------------\n");
p=a;//reset data
printf("%d\n",(*p)++);
printf("%d\n",*p);
for(i=0;i<3;i++)
printf("%d ",a[i]);
printf("\n");
printf("----------------3----------------\n");
a[0]=1;//reset data
p=a;
printf("%d\n",*(p++));
printf("%d\n",*p);
for(i=0;i<3;i++)
printf("%d ",a[i]);
printf("\n");
printf("----------------4----------------\n");
p=a;
printf("%d\n",++*p);
printf("%d\n",*p);
for(i=0;i<3;i++)
printf("%d ",a[i]);
printf("\n");
printf("----------------5----------------\n");
p=a;
a[0]=1;
printf("%d\n",++(*p));
printf("%d\n",*p);
for(i=0;i<3;i++)
printf("%d ",a[i]);
printf("\n");
printf("----------------6----------------\n");
p=a;
a[0]=1;
printf("%d\n",*(++p));
printf("%d\n",*p);
for(i=0;i<3;i++)
printf("%d ",a[i]);
printf("\n");
return 0;
}
輸出結(jié)果是這樣的:

第一組:*p++,它的運算順序是先返回 *p的值,然后p再++。
第二組:(*p)++,他的運算順序是先返回 *p的值,然后 *p的值再++,這一點從運算后的數(shù)組a的值可以看出來。
第三組:*(p++),運算順序是先返回 *p的值,然后p再++,也就是說它和 *p++的運算順序一樣。
這三組都是先返回 *p的值,區(qū)別就在于到底是p++還是 *p的值++。
第四組:++*p,先將 *p的值++,然后再返回 *p的值。
第五組:++(*p),先將 *p的值++,然后再返回 *p的值,所以它和++ *p是一樣的。
第六組: * (++p),先將p的值++,然后再返回 * p的值,和 *++p是等價的。
這三組的特點是最后都是返回 *p的值,不同點在于是 *p先++還是p++。
以上就是本文的全部內(nèi)容,希望大家可以喜歡。
相關(guān)文章
C語言詳解如何實現(xiàn)堆及堆的結(jié)構(gòu)與接口
堆是計算機科學(xué)中一類特殊的數(shù)據(jù)結(jié)構(gòu)的統(tǒng)稱,通常是一個可以被看做一棵完全二叉樹的數(shù)組對象。而堆排序是利用堆這種數(shù)據(jù)結(jié)構(gòu)所設(shè)計的一種排序算法。本文將詳細介紹堆的結(jié)構(gòu)與接口,需要的可以參考一下2022-04-04
C/C++ 中memset() 函數(shù)詳解及其作用介紹
這篇文章主要介紹了C/C++ 中memset() 函數(shù)詳解及其作用介紹,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07

