C++中的函数重载通常根据参数类型及个数来实现,但当含有引用参数和非引用参数时会出现一些问题,先见如下代码:
bool str_equal(string str1 , string str2){
cout<<"str_equal no & no const"<<endl;
return str1.size() == str2.size();
}
bool str_equal(const string str1 , const string str2){
cout<<"str_equal with const no &"<<endl;
return str1.size() == str2.size();
}
这里,编译时会报重复定义的错误:
[Error] redefinition of 'bool str_equal(std::string, std::string)'
这里应该都明白在函数调用时无法通过const来选择函数;但如果形参是引用,则情况会有所变化,请看如下代码
bool str_equal(string& str1 , string& str2){
cout<<"str_equal with & no const"<<endl;
return str1.size() == str2.size();
}
bool str_equal(const string& str1 , const string& str2){
cout<<"str_equal with const &"<<endl;
return str1.size() == str2.size();
}
像这样,就能编译通过,这也说明形参为引用时,在调用函数可以通过const来选择
同样,在形参为指针时,在调用函数时也可以通过const来选择