概述
c++中把函数不会改变的形参定义为普通的引用是一种常见的错误,这么做给函数的调用者一种误导,即函数可以修改它的实参的值.此外,使用引用而非常量引用极大的限制了函数所能接受的实参的类型.因为我们不能把const对象字面值或者需要类型转换的对象传递给普通的引用形参.
这种错误绝不像看起来这么简单,它可能造成出人意料的结果.例如我们定义函数声明:string::size_type find_char(string &s,char c,string::size_type &occurs);则只能将find_char函数作用于string对象.类似这样的调用find_char("hello worlld",'o',ctr);将在编译时发生错误.
还有一个更难察觉的问题,假如其他函数将它们的形参定义为常量引用,那么第二个版本的find_char无法在此类函数中正常使用。比如,我们希望在一个判断string对象是否是句子的函数中使用find_char:
bool is_senstence(const string &s){
//若在s的末尾有且只有一个句号,则s是一个句子
string::size_type ctr=0;
return find_char(s,'.',ctr)==s.size-1&&ctr==1;
}
如果find_char的第一个形参类型是string&,那么上面这条调用find_char将在编译时发生错误。原因是s是常量引用,但find_char被定义成只能接受普通引用。
解决这一问题的一种思路是将is_sentence中的参数改为普通引用,但这么做只不过是转移了错误而已,结果是is_sentence函数的调用者只能接受非常量的string对象了。
正确的修改思路是改正find_char中的形参。如果实在不能修改,就在is_sentence中定义一个string类型的变量,令其为s的副本,然后把这个string对象传递给find_char。
最后
以上就是害羞可乐为你收集整理的尽量使用常量引用的全部内容,希望文章能够帮你解决尽量使用常量引用所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复