首先要搞清楚char *str和char str[]
char c[] = "hello world";
是分配一个局部数组;
char *c = "hello world";
是分配一个全局数组。
局部数组是局部变量,它所对应的是内存中的栈。全局数组是全局变量,它所对应的是内存中的全局区域。字符串常量保存在只读的数据段,而不是像全局变量那样保存在普通数据段(静态存储区),如:
char *c = "hello world";
*c = 't'; //error
c占用一个存储区域,但是局部区的数据是可以修改的:
char c[] = "hello world";
c[0] = 't'; //OK
这里c不占存储空间。
另外,也可以这样修改:
const char *strA()
{
static char str[] = "hello world";
return str;
}
通过static开辟一段静态存储空间。
下面这个函数有无问题,该如何修改?
char *strA()
{
char str[] = "hello world";
return str;
}
这个str里存的地址是函数strA栈帧里“hello world”的首地址。函数调用完成,栈帧恢复到调用strA之前的状态,临时空间被重置,堆栈“回缩”,strA栈帧不再属于应该访问的范围。存于strA栈帧里的“hello world”当然也不应该访问了。
这段程序可以正确输出结果,但这种访问方法违背了函数的栈帧机制。
如果想获得正确的函数,改成下面形式:
const char * strA()
{
char *str = "hello world";
return str;
}