- string类定义了一种char*到string的转换功能,这使得可以使用C-风格字符串来初始化string对象。
- 类型为const引用的形参其中一个属性表明:假设实参的参数类型与引用参数不匹配,但可以转换为引用类型,程序将创建一个正确类型的临时变量,使用转换后的实参值来初始化它,然后传递一个指向该临时变量的引用。
- 上面提到const引用为形参的属性,也就是说,如果引用的参数是const,则编译器在某些情况下会生成临时变量,比如下面这两种情况:
1, 实参类型不正确,但可以转换为正确类型。
2, 实参类型正确,但不是左值
先看到下面例子
void g(string &a,const string &b)
{
cout<<"a address :"<<&a<<endl;
cout<<"b address :"<<&b<<endl;
// return a;
}
string f()
{
}
int main()
{
string input="I love you";
int a=1;
// int b=2;
cout<< "input address: "<<&input<<endl;
const char *b="***";
cout<<"b address: "<<&b<<endl;
g(input,b);
// g(input,input);
getchar();
return 0;
}
可以看到g函数的参数一个为string& 一个为 const string&
我们将input="I love you"和const char b="**";作为参数传入g函数,分别打印传入前和传入后变量的地址我们来看一下结果。
可以看到将字符串常量传给g函数的const string&参数打印出的地址与传入的地址不同,这说明函数自动生成了一个临时变量将字符串常量自动转化为string类型。
那我们再看另一个例子
1 string f();
2 string g(string & str);
3
4 g(f());
5 g("abc");
程序编译在4,5行出错,这是为什么呢。
第5行的错误可以由上面的例子解释,当引用参数与实参不匹配,但可以通过转化为引用类型时,要将引用声明为const。
第4行的错误可以知道,将一个临时变量作为实参传递给参数时,也同样需要将参数类型设为const。
以上是针对string类型的参数做的实验,那么其他类型的参数是不是也同样是这样的规则呢?
1 void g(int &a,const char &b)
2 {
3 cout<<"a address :"<<&a<<endl;
4 cout<<"b address :"<<&b<<endl;
5
6 // return a;
7 }
8
9 string f()
10 {
11 }
12 int main()
13 {
14
15 int a=1;
16 int b=2;
17 cout<< "a address: "<<&a<<endl;
18 cout<<"b address: "<<&b<<endl;
19
20 g(a,b);
21
22 // g(input,input);
23
24 getchar();
25 return 0;
26 }
我们将参数参数改为int& 和 const char&引用,将两个整形变量传递给函数。发现结果和上面一样,同样产生了临时变量。
总结
在c++中当函数参数为引用时。
- 如果传递的实参与函数参数类型不匹配,那么只有将参数类型定义为const,那函数将会产生一个临时变量,临时变量自动转化为函数参数类型。否者将报错。
- 如果传递的实参是一个临时变量,那么就要将函数参数定义为const类型,否则也会出错
原文链接: https://www.cnblogs.com/a-lai/p/7338316.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/258157
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!