成员函数定义后面加const是什么功能:C++中const成员函数的作用

成员函数定义后面加const是什么功能:C++中const成员函数的作用

在这里插入图片描述

前言

在PX4的代码中的位置控制模块中,有这样一个成员函数

void getAttitudeSetpoint(vehicle_attitude_setpoint_s &attitude_setpoint) const;

该函数的功能是:在位置控制器经过更新后得到了期望的油门向量,通过这个函数转换为期望姿态值。

可以看到函数的声明和定义时,后面都加了一个const关键字在这个地方这个关键字是做什么用的呢?

在C++中,成员函数后的 const 关键字表示该函数是常量成员函数。

C++中const成员函数的作用

在C++中,成员函数后的 const 关键字表示该函数是常量成员函数,其作用如下:

1、不可修改对象状态

  • const 成员函数承诺不会修改类的非静态成员变量(除非成员被 mutable 修饰)。
  • 在函数内部尝试修改成员变量会导致编译错误(除非变量是 mutable 的)。

2、允许在const 对象上调用

  • 只有 const 成员函数才能被 const 对象调用。例如:
const PositionControl controller;
controller.getAttitudeSetpoint(...);  // 正确:调用 const 成员函数
PositionControl controller;
controller.getAttitudeSetpoint(...);  // 正确:非const对象也可以调用 const 成员函数
  • 非 const 成员函数无法在 const 对象上调用。
const PositionControl controller;
controller.setInputSetpoint(...);  // 错误:const对象只能调用 const 成员函数,而setInputSetpoint为非const 成员函数

3、 明确设计意图

  • 函数名后的 const 明确告知调用者:此函数仅用于查询或获取数据,不会改变对象内部状态。
  • 在示例中,getAttitudeSetpoint 用于获取姿态设定点,而非修改控制器状态,因此标记为 const 是合理的。

4、参数与 const 的关系

  • 示例中的参数 vehicle_attitude_setpoint_s &attitude_setpoint 是一个非 const 引用,函数可能通过此引用修改外部传入的对象。

  • 但函数本身的 const 仅约束对类内部状态的修改,不影响参数的行为。

总结

const 成员函数是 C++ 的常量正确性(const-correctness)机制,确保函数:

  • 不意外修改对象状态。
  • 可在 const 上下文中安全使用。
  • 提升代码可读性和安全性。

在示例中,getAttitudeSetpoint 用于获取姿态设定点,而非修改控制器状态,因此标记为 const 是合理的。

示例中的参数 vehicle_attitude_setpoint_s &attitude_setpoint 是一个非 const 引用,函数可能通过此引用修改外部传入的对象。

<think>嗯,用户想深入了解C++中函数声明后面const的意义,这是个基础但容易混淆的概念。用户引用了我之前关于const成员函数的描述(对象状态保护、const对象调用权限等),但这次提问更聚焦于"声明语法"本身,需要更系统地讲解语法、语义和应用场景。用户展示过代码示例(Test类中的const成员函数),但示例里有个关键细节:test()函数试图调用非const成员函数geta()。这恰好是容易出错的地方,我应该在回答中强调——const成员函数只能调用其他const成员函数[^1]。另外用户提到的QString案例值得保留,它是标准库级的最佳实践。用户身份可能是:刚接触C++面向对象编程的开发者,或在阅读Qt等库代码时遇到const方法产生疑惑。提问方式说明他/她已经查阅过资料,但需要概念串联和常见陷阱提示。深层需求可能是想写出更安全的API设计,或调试const对象相关的编译错误。接下来组织答案时注意:1)先区分顶层const成员函数const(用户问的是后者);2)用对比表格说明重载差异;3)强调mutable的特殊性(用户示例没涉及这点);4)补充"逻辑常量性"概念(和物理常量性对应),避免用户误以为const完全禁止修改。最后生成问题时要覆盖用户可能遇到的延伸场景:如何处理成员函数返回内部指针的const性?为什么有的const函数实际修改了数据(如缓存更新)?</think> ### C++ 函数声明后 `const` 的作用与意义 在 C++ 中,成员函数声明后 `const` 修饰符(如 `void func() const;`)具有以下核心特性和作用: --- #### **1. 保证对象状态不变性** - **作用**:标记该成员函数不会修改类的任何**非 `mutable` 成员变量**。 - **示例**: ```cpp class Counter { int count = 0; // 普通成员变量 mutable int access = 0; // mutable 成员变量 public: int getCount() const { // count++; // 错误:禁止修改非 mutable 成员 access++; // 合法:允许修改 mutable 成员 return count; } }; ``` - **编译检查**:若函数尝试修改非 `mutable` 成员,编译器直接报错[^1]。 --- #### **2. 支持 const 对象调用** - **权限控制**:`const` 对象(如 `const MyClass obj;`)**只能调用 const 成员函数**。 - **示例**: ```cpp const Counter c; c.getCount(); // 合法(getCount 是 const 函数) // c.reset(); // 错误:reset() 若非 const 函数则不可调用 ``` - **设计意义**:确保 `const` 对象的逻辑不可变性[^2]。 --- #### **3. 参与函数重载** - **签名区分**:`const` 是函数签名的一部分,允许定义同名但 `const` 属性不同的重载函数。 - **应用场景**: ```cpp class Data { std::vector<int> values; public: // 非 const 版本:允许修改成员 int& operator[](int index) { return values[index]; } // const 版本:只读访问 const int& operator[](int index) const { return values[index]; } }; ``` - **编译器决策**: - `Data d; d[0] = 5;` 调用非 `const` 版本 - `const Data cd; cd[0];` 调用 `const` 版本 --- #### **4. 提高代码健壮性与可读性** - **可读性**:明确标识函数的只读性质,降低理解成本。 - **健壮性**: - 防止意外修改对象状态 - 支持多线程安全访问(`const` 函数天然具备线程安全基础,但需配合其他机制) --- ### 关键注意事项 1. **`mutable` 成员**: ```cpp mutable int cache; // 可在 const 函数中被修改 ``` 2. **调用限制**: - `const` 成员函数**只能调用其他 `const` 成员函数**(如示例中的 `getCount()` 调用其他 `const` 函数)。 3. **返回类型**: - 返回内部数据时,通常返回 `const` 引用(如 `const int&`),防止外部意外修改。 --- ### 总结 | **特性** | **作用** | |---------------------|---------------------------------------| | 对象状态保护 | 禁止修改非 `mutable` 成员 | | `const` 对象支持 | 允许 `const` 对象调用 | | 函数重载 | 与非 `const` 版本区分 | | 代码健壮性 | 防止误操作,提高线程安全基础 | 相关问题: 1. `mutable` 成员变量在哪些场景下适用? 2. `const` 成员函数中如何修改类的状态? 3. 如果函数同时被 `const` 和 `volatile` 修饰,会发生什么? 4. `const` 成员函数如何影响对象的拷贝和移动语义?
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

月照银海似蛟龙

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值