一个基础但是隐晦的c++语法问题

本文深入探讨了C++中const修饰符的使用方法及其在实际编程中的常见陷阱。通过具体的代码示例,解释了当const用于指针时,如何区分指针所指向的数据和指针本身的常量特性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、工作现场代码:

typedef MyData
{
    int data1;
    int data2;
} * LPMYDATA;

const LPMYDATA pData = getData();
// do sth else
pData = getNewData();   // compile error

2、分析:

a、首先我们应该都知道const的使用方法,一些面试题也都喜欢考察这个问题,比如 const char* 和 char const* 和char * const有什么区别。

前两个是等价的,const在指针前面则指针指向的实际内存区域不可修改,const在指针后面,则指针本身不可修改。如果前后都有则都不可修改。

b、虽然我不喜欢在c++代码中用这种typedef来定义结构,但是上面这种typedef用法是没有什么问题的。但是为什么无法给pData进行第二次赋值? pData为什么变成不可修改的常量了?


3、结论:

typdef xxx *PXXX; 经过这种typedef后,PXXX已经是一个整体类型,而不是一个普通的define形式的字符串替换。 按照上面的分析,const char*和char const*是完全等价的,也就是说对于编译器而言,const在类型前后是等价的。于是const LPMYDATA就等价于LPMYDATA const。 这个时候再看,const LPMYDATA pData;这句话在编译器理解应该是这样的:

MyData* const pData;
这样就可以看到,const修饰的确实是指针本身。那上面编译不过的那句就可以理解了。


这个问题虽然比较隐晦,但是确实是我们工作中容易犯的错误,犯这个错误也可以反映出基本功还不够扎实。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值