关于返回引用的问题,关于模板的问题,关于返回const类型的问题
#include <iostream>
#include <fstream>
using namespace std;
template <class T>
inline const T& max(const T& a, const T& b)
{
return a <b ? b:a;
}
int main()
{
int a,b=9;
a=3;
cout < <max(a,b) < <endl;
return 0;
}
问题1:程序编译不过去,为什么?
问题2:返回引用会在内存上有什么不能,参数为引用当然好解释。
问题3:返回const什么实际的意义
[解决办法]
using namespace std;
换成
using std::cout;
using std::endl;
因为std里面有个max, 会冲突.
如果模板是以 自定义类型 实例化, 调用时可省去调用拷贝构造函数的开销. 但不能返回函数内的局部变量, 最好不返回函数内的静态变量.
返回const 禁止调用函数内修改被调用函数返回值.
[解决办法]
1。与标准库中的max冲突,所以导致解析函数调用时多义。
2。不能返回函数内局部变量的引用。或者说,不能返回栈对象的引用。因为函数结束的时候,栈对象已经过了生存有效期,对象已经被析构,所以返回一个到局部变量的引用,后面访问的时候,会出错的。
3。返回const值,可以保证返回的对象不能做为左值。
比如说:
class myClass{
}
如果我们重载了operator+,
const myClass& operator+(const myClass& lhs, const myClass& rhs)
{
......
}
如果上面函数返回的值不是const,那么就可以有下面的合法表达式:
myClass val1, val2, val3, val4;
val1 + val2 = val3 + val4;
这种写法不符合一般的语义表达,是应该避免的。通过让operator+返回一个const,就可以避免上面的情况
[解决办法]
问题1:程序编译不过去,为什么?
名字冲突了,把max改成mmax或其它即可
问题2:返回引用会在内存上有什么不能,参数为引用当然好解释。
当在函数体内写一个局部变量时,不能用引用来返回,而为返回的时候,局部变量已经消失,返回的将是垃圾
问题3:返回const什么实际的意义
防止返回的值被修改.特别是用引用来接收返回值,对引用的修改可以直接影响到内部变量