指针的运算等级*p++等问题

指针的运算等级*p++等问题,第1张

在C语言的指针这一节,有一个很经典的问题,那就是当表达式中出现,*p++ , *(p++) , *++p ,( *p)++ , ++ *p,这一系列的问题时,如何弄清楚这些表达式的具体含义和执行顺序相信困扰的不只是一个人。

前置背景知识

具体的优先级可以参考这张表,我们可以明白* 解引用运算符和 ++自增运算符属于同一优先级,并且同时支持从右到左的运算顺序。具体完整的优先级可以参考链接:c++运算符优先级

*p++

废话不多说,我们直接上例程进行分析

    int arr[]={1,4,5,9};
    int *p=arr;
    cout<<p<<" "<<&p<<" "<<*p<<endl;
    //先将*p赋给a,然后再将执行p++;
    int a=*p++;

    cout<<"a ="<<a<<" "<<p<<" "<<&p<<" "<<*p<<endl;

输出结果:
     0x61fe00 0x61fdf8 1
a =1 0x61fe04 0x61fdf8 4

**可以明显的看到a=p++ ,实现先将 p的值赋给a,然后p自加,指向下一个地址。相信看到这,大家会跟我一样很懵逼,以为安装优先级推断应该是先p++,再将 * p++赋给a吗,其原因主要是当++运算符放到变量的右侧需要等待整个表达式运算完了之后才能进行接下来的运算,类似于i++和++i之间的区别。 i++是先赋值后自加,++i是先自加再赋值。

*(p++)
    cout<<p<<" "<<&p<<" "<<*p<<endl;
	int a=*(p++);
    cout<<"a ="<<a<<" "<<p<<" "<<&p<<" "<<*p<<endl;

输出结果:
     0x61fe00 0x61fdf8 1
a =1 0x61fe04 0x61fdf8 4

*(p++) 和 *p++的结果和含义一致,也是++ 要等整个表达式运行完才能进行计算,跟是否有()影响不大,所以实现的结果*也是,先将 p的值赋给a,然后p自加,指向下一个地址

*++p
    cout<<p<<" "<<&p<<" "<<*p<<endl;
	//先执行p++再将*p赋给b
    int b=*++p;
    cout<<"b ="<<b<<" "<<p<<" "<<&p<<" "<<*p<<endl;

输出结果:
	 0x61fe00 0x61fdf8 1
b =4 0x61fe04 0x61fdf8 4

此时,由于++运算符在变量的左侧,所以要严格按照从右到左的顺序,先只执行 p++,p指向下一个地址,再将 ++p的值赋给 b

++*p
    cout<<p<<" "<<&p<<" "<<*p<<endl;
	//先取*p的值,再将这个值自加赋给a
    int a=++*p;
    cout<<"a ="<<a<<" "<<p<<" "<<&p<<" "<<*p<<endl;

输出结果:
     0x61fe00 0x61fdf8 1
a =2 0x61fe00 0x61fdf8 2

*先执行*p *** 作,解引用 p的值,然后将该解引用的值自加,并将自加的结果赋给a

(*p)++
   cout<<p<<" "<<&p<<" "<<*p<<endl;
   //先将取*p的值赋给a,再*p的值自加
    int a=(*p)++;
    cout<<"a ="<<a<<" "<<p<<" "<<&p<<" "<<*p<<endl;
参考答案:
	 0x61fe00 0x61fdf8 1
a =1 0x61fe00 0x61fdf8 2

++在变量的右边,因此*先取*p的解引用的值赋给a,再执行将 p的解引用的值自加

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/874740.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-13
下一篇 2022-05-13

发表评论

登录后才能评论

评论列表(0条)

保存