局部常量字符串指针及常量字符串数组 返回值

问题1:
#include "stdio.h"
char *get_string_1()
{
    char p[] = "hello world!"; //p数组作为局部变量被存储在栈区;在定义p数组时同时将其内容初始化

    return p;                  //为"hello world!", 也就是说此处的"hello world!"只是用来初始化p数  

                              // 组的内容。  就像int a=5 中的5一样。


 char *get_string_2()
{
    char *p = "hello world!";  //"hello world!"被存储在静态数据区,而且是全局的,p仅仅就是个指针,
    return p;                  //指向这个区域。
}
int main()
{
    char *p;
    p = get_string_1();
    printf("get_string_1:%sn",p);
    p = get_string_2();
    printf("get_string_2:%sn",p);
    return 0;
}
输出:
get_string_1:(乱码或者没有输出),linux下没有任何输出
get_string_2:hello world!     返回值指向了静态数据区的"hello world! "。

解析:

       char *p = "hello world!";与char p[] = "hello world!"; 两者都用来声明一个字符串,并将其初始化为hello world!,但是表示的意义确是大不相同。
       从其声明的对象来说:
       char p[] = "hello world!";用来声明一个数组p,数组大小为12字节。
       char *p = "hello world!";用来声明一个指针p,指向“hello world!”字符串起始位置。
       从存储位置来说:
       char p[] = "hello world!";p数组作为局部变量被存储在栈区;
       char *p = "hello world!"; 在这个声明中,"hello world!"被存储在静态数据区,而且是全局的,p仅仅就是个指针,指向这个区域。不信的话你可以试试下边的代码,看是不是同一个地址:
       char *p1 = "hello world!";
       char *p2 = "hello world!";
       printf("p1:%xnp2:%xn",p1,p2);
       从函数执行后的扫尾工作来看:
       C函数执行完之后对栈区进行清除操作,对静态数据区和堆则没有,因此第一个问题也就不难解释了,get_string_1()函数执行完就释放了栈区内存,所以根本就不存在存有"hello world!"声明时的内存,也就不可能有所输出。


问题2: char *p = "hello world!";这样写到底合不合法,实际应用中能不能这样写。

解析:这是一个历史问题,在const关键字被引入C语言之前,这样写是合法的,而且存在了很长的一段时间,大量的代码在此期间运用了这种写法,新版C语言为了兼容,故允许这样写,但最好不要这样,因为这种写法终会被淘汰,说不定哪天你的代码用了新版的编译器,然后莫名的出了问题,要找这个BUG估计不是一件容易的事。现在最好写成:
        const char *p = "hello world!";
        或者
        char p[] = "hello world!";


问题3:char *p = "hello world!";与char p[]="hello world!";有什么细节和操作上的差异。

解析: 

        1. char *p = "hello world!"; 可以用p++操作,sizeof(p) == 4;
        2.char p[]="hello world!"; sizeof(p) == 12;


  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值