在c语言中,通常有两种方式来建立字符串ios
//第一种,利用字符指针 char* p = "hello"; //第二种:利用字符数组 char str[] = "hello";
那么,它们之间有什么区别呢?以例子说明:数组
#include<stdio.h> #include<iostream> char* returnStr() { char* p = "hello world!"; return p; } int main() { char* str = NULL; str = returnStr(); printf("%s\n", str); system("pause"); return 0; }
输出:函数
以上代码是没有问题的,"hello world"是一个字符串常量,存储在常量区,p指针指向该常量的首字符的地址,当returnStr函数退出时,常量区中仍然存在该常量,所以仍然能够用指针访问到。spa
#include<stdio.h> #include<iostream> char* returnStr() { char p[] = "hello world!"; return p; } int main() { char* str = NULL; str = returnStr(); printf("%s\n", str); system("pause"); return 0; }
输出:指针
以上代码有问题,输出为乱码。这一段代码和以前的最主要的区别就是returnStr中字符串的定义不一样。这里使用字符数组定义字符串。所以这里的字符串并非一个字符串常量,该字符串为局部变量,存查在栈中,当returnStr函数退出时,该字符串就被释放了,所以再利用指针进行访问时就会访问不到,输出一堆乱码。code
固然 ,若是将char p[] = "hello world!";声明为全局变量,即:blog
#include<stdio.h> #include<iostream> char p[] = "hello world!"; char* returnStr() { return p; } int main() { char* str = NULL; str = returnStr(); printf("%s\n", str); system("pause"); return 0; }
那么,该字符串就会存储在全局变量区,通常将全局变量区和静态资源区和常量区视为一个内存空间。所以,一样能够使用指针访问到。内存
输出:资源