C++函数中const形参与非const形参

在程序设计中我们会经常调用函数,调用函数就会涉及参数的问题,那么在形参列表中const形参与非const形参对传递过来的实参有什么要求呢?

先来看一个简单的例子:

#include <iostream>
#include <string>
using namespace std;
void print_str(const string s)
{
      cout<<s<<endl;
}
int main()
{   
      print_str("hello world");
      return 0;
}


毫无疑问,const实参传递给const形参,正确调用函数,如果你将第4行代码中的const去掉,也能得到正确的结果。那么在去掉const的基础上将形参变为引用形参,会出现什么样的结果呢?看下面的代码:

#include <iostream>
#include <string>
using namespace std;
void print_str( string & s)
{
      cout<<s<<endl;
}
int main()
{   
      print_str("hello world");
      return 0;
}


发现编译不通过,如果在第4行的string前加上一个const,就会通过编译。进一步研究我们会发现指针形参与引用形参会出现类似的情况。

普通形参加不加const限定符对实参没有影响,引用形参和指针形参前面没有const限定符时,实参必须是非const的,而前面有const限定符时对实参也没有什么影响

为什么会出现这种情况?

原因在于实参的传递方式不同,函数中的形参是普通形参的时,函数只是操纵的实参的副本,而无法去修改实参,实参会想,你形参反正改变不了我的值,那么你有没有const还有什么意义吗?引用形参和指针形参就下不同了,函数是对实参直接操纵,没有const的形参时实参的值是可以改变的,这种情况下怎能用函数来操纵const实参呢。


### C++ 中 `const` 参数与 `const` 参数的区别 在 C++ 函数定义中,参数可以声明为 `const` 或者 `const` 类型。这两种类型的参数有着同的行为和适用场景。 #### 1. 行为差异 当函数接收一个 `const` 参考或指针作为参数时,在该函数的作用域内允许改变此参数所指向的对象的状态[^3]: ```cpp void modifyValue(int& value) { ++value; } void dontModifyValue(const int& value) { // 下面这行会编译错误:无法更改 const 对象 // ++value; } ``` 对于 `const` 参数,则可以在函数体内自由地对其进行操作而会引发编译期错误。 #### 2. 使用场景 ##### 值传递方式下 - ** `const`**: 如果需要保护原始数据,并且希望允许调用方看到任何可能的变化(比如通过返回值),则可以选择 `const` 关键字。 - **`const`**: 当仅需读取而打算修改实参的时候应该上 `const`,这样仅表达了意图还增了安全性;另外,这样做也使得大对象能够以引用式高效传输而是拷贝整个实体[^4]。 ##### 引用/指针传递方式下 - ** `const` 引用或指针** : 这种情况下可以直接访问并修改实际参数的内容。适用于那些确实需要对外部变量做出变更的操作,例如交换两个整数的位置等情。 - **`const` 引用或指针** :确保了即使是指向外部存储区的数据也会被意外篡改,增强了接口的一致性和可靠性。特别是处理复杂结构体或是容器类实例时尤为有用。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值