• C语言中返回字符串函数的四种实现方法


    有四种方式:
    1。使用堆空间,返回申请的堆地址,注意释放
    2。函数参数传递指针,返回该指针
    3。返回函数内定义的静态变量(共享)
    4。返回全局变量
     
    ******************以下摘自csdn******************************
     
    其实就是要返回一个有效的指针,尾部变量退出后就无效了。 

    使用分配的内存,地址是有效 
    char   *fun() 

            char*   s   =   (char*)calloc(100,   sizeof(char*)   ); 
            if   (s) 
                    strcpy   (   s   ,   "abc "   ); 
            return   s; 

    但这种方式需要注意,必须由使用将将返回的地址free掉 

    将地址由入参传入 
    char*   fun(char*s) 

            if   (s) 
                  strcpy(s,   "abc "); 
            return   s; 

    这种方式调用都要注意给s分配的大小是足够。 
    可以这样: 
    char*   fun(char*s,   int   len) 

            if   (s) 
            { 
                  strncpy(s,   "abc ",   len-1); 
                  s[len-1]   =   0; 
            } 
            return   s; 


    或才使用局部静态变量 
    char*   fun() 

            static   char   s[100]; 
            strcpy(s,   "abc "); 
            return   s; 

    这种方式需要注意,不要修改返回的这个字符串,由于是共享地址,对它的修改会反应到每个调用者的。可以这样: 
    const   char*   fun() 

            static   char   s[100]; 
            strcpy(s,   "abc "); 
            return   s; 


    还有一种是使用全局变量 
    char   g_s[100]; 
    char*   fun() 

            strcpy(g_s,   "abc "); 
            return   s; 

    同样的,也要注意这个变量可存储的最大空间。
     
    转载自 turkeyzhou
    http://blog.csdn.net/turkeyzhou/article/details/6104135
  • 相关阅读:
    【转载】搜索题目推荐
    HDU 4629 Burning 几何 + 扫描线
    HDU 4630 No Pain No Game 树状数组+离线查询
    SPOJ 416 Divisibility by 15 细节题
    【转载】树状数组题目
    SPOJ 274 Johnny and the Watermelon Plantation(TLE)
    SPOJ 227 Ordering the Soldiers 线段树 / 树状数组
    HDU 4620 Fruit Ninja Extreme 搜索
    Java序列化与反序列化
    Java IO包装流如何关闭?
  • 原文地址:https://www.cnblogs.com/dmyu/p/5638797.html
Copyright © 2020-2023  润新知