函数中的数组
1.
char* getMem() { char p[] = "Hello world"; p[5] = 0x0; return p; }
p是一个数组,是一个局部变量,说明这个函数执行完毕之后p数组中的值都被销毁了
如果单独使用p,则p表示这块数组的首地址。函数返回值按值传递是p,仅仅传递p的地址,而p数组中的内容都被销毁了。
2.
char* getMem() { char* p = "hello world"; p[5] = 0x0; return p; }
常量区的字符不能修改。
3.
char* getMem() { char* p = "hello world"; return p; }
正确,helloworld存在于常量区。不会随着函数结束而销毁
4.
string& getMem() { string s = "hello world"; string& rs = s; return rs; }
string ss = getMem(); 错误。因为s是局部变量,返回值是一个引用,本质上在临时区建立了一个引用,这个临时的引用引用了rs,也就是s。但是函数结束后s被销毁。但是引用不能为空。所以错误
string& rs = getMem(); 错误,因为rs是s的引用,s已经销毁,rs返回一个乱码值。表达式成立是因为返回值是一个引用,引用是一个左值,可以通过左值引用来引用。
5.
string getMem() { string s = "Hello world"; string& rs = s; return rs; }
string ss = getMem(); 正确,值传递ss是一个新的局部变量,完全拷贝了getMem的返回值
string& ss = getMem(); 错误,getMem返回值是一个临时变量,也就是右值,不能用左值引用来引用
const string& crs = getMem(); 正确,右值可以使用const引用来引用
6.
string getMem(string& s) { string& rs = s; return rs; }
string s = "hello world";
string ss = getMem(s); 正确
string& rs = getMem(s); 错误,
const string& rs = getMem(s); 正确
7.
string& getMem(string& s) { string& rs = s; return rs; }
string s = "hello world";
string ss = getMem(s); 正确,用外面的s初始化ss
string& rs = getMem(s); 正确,rs指向s,s的作用域没有结束