#include <cstdio>
char* get_str()
{
char *str = {"abcd"};//可以
//char str[] = {"abcd"};//错误,结果不确定
return str;
}
int main()
{
char* p = get_str();
printf("%s ", p);
return 0;
}
char *str = {"abcd"};//可以,是因为"abcd"是一个字符串常量,它并不在一个栈空间上,而是在静态存储区上。
字符串的生命周期是:程序开始时分配,程序结束时释放。
(当然,str是一个指针变量,在栈空间上,因此函数返回时会释放,但是所指为字符串常量,字符串常量所占空间在函数返回时不会释放)
而char str[] = {"abcd"};//错误,结果不确定,虽然从编译器的实现来看(见如下代码(VC6下)的结果),"abcd"仍然是当成一个字符串常量,但是程序又把它复制了一次,放在了栈空间上,返回的时候str所指的是栈上的这一块字符串。问题的本质仍然是由于返回了指向栈空间的指针。
//5: char *str = {"abcd"};
//00401038 mov dword ptr [ebp-4],offset string "abcd" (0042201c)
//6: return str;
//0040103F mov eax,dword ptr [ebp-4]
//5: char str[] = {"abcd"};
//00401038 mov eax,[string "abcd" (0042201c)]
//0040103D mov dword ptr [ebp-8],eax
//00401040 mov cl,byte ptr [string "abcd"+4 (00422020)]
//00401046 mov byte ptr [ebp-4],cl
//6: return str;
//00401049 lea eax,[ebp-8]
这是我在其他地方看到的解释
就麻烦高手们给解释下这段汇编的意思了