欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言中函數(shù)返回字符串的方法匯總

 更新時(shí)間:2017年05月21日 10:06:35   作者:qingergege  
C語(yǔ)言返回字符串函數(shù)共有四種方式,分別如下:使用堆空間,返回申請(qǐng)的堆地址,注意釋放、函數(shù)參數(shù)傳遞指針,返回該指針、返回函數(shù)內(nèi)定義的靜態(tài)變量(共享)、返回全局變量

在討論著四種方法之前,首先要對(duì)函數(shù)有一個(gè)簡(jiǎn)單的認(rèn)識(shí),無(wú)論是在形實(shí)結(jié)合時(shí),還是在return語(yǔ)句返回時(shí),都有一個(gè)拷貝的過(guò)程。你傳進(jìn)來(lái)的參數(shù)是個(gè)值,自然函數(shù)在工作之前要把這個(gè)值拷貝一份供自己使用,你傳進(jìn)來(lái)的是個(gè)地址,函數(shù)也就會(huì)拷貝該地址供自己使用。同樣return返回時(shí),如果返回一個(gè)值,函數(shù)會(huì)將該值拷貝一份以提供給主調(diào)函數(shù)使用,返回的是一個(gè)指針(也就是地址),自然拷貝的就是一個(gè)地址,供主調(diào)函數(shù)使用。

先給出一個(gè)錯(cuò)誤的例子:

#include <stdio.h>
#include <string.h>

char * retstring();
int main()
{
  char * name2;
  name2 = retstring();
  printf("%s\n",name2);
  return 0;
}

char * retstring()
{
  char name[10]; 
  strcpy(name,"漢青");
  return name;
}

編譯一下代碼,會(huì)發(fā)現(xiàn)提示一個(gè)警告,大概意思就是說(shuō)返回了一個(gè)局部變量的地址。這個(gè)程序的輸出結(jié)果是不確定的,因?yàn)槲覀兌贾溃植孔兞康纳嫫谑蔷驮趬K內(nèi)部,這里也就是在函數(shù)retstring()的內(nèi)部,在main函數(shù)中,name的內(nèi)存空間已經(jīng)被回收。

所以不能返回一個(gè)自動(dòng)變量的字符串。。。

下面給出四種返回字符串的方法:

1、 將字符串指針作為函數(shù)參數(shù)傳入,并返回該指針。

2、 使用malloc函數(shù)動(dòng)態(tài)分配內(nèi)存,注意在主調(diào)函數(shù)中釋放。

3、 返回一個(gè)靜態(tài)局部變量。

4、 使用全局變量。

下面是詳細(xì)解釋:

方法一:將字符串指針作為函數(shù)參數(shù)傳入,并返回該指針。

典型的strcpy()函數(shù)應(yīng)該就是采用的這種方法,第一個(gè)參數(shù)為指向目的字符串的指針,返回值也為這個(gè)指針。

char* strcpy(char* des,const char* source)
 
{
 
 char* r=des;
  
 assert((des != NULL) && (source != NULL));
 
 while((*r++ = *source++)!='\0');
 
 return des;
 
}

方法二:使用malloc函數(shù)動(dòng)態(tài)分配,但是一定要注意在主調(diào)函數(shù)中將其釋放,應(yīng)為malloc動(dòng)態(tài)分配的內(nèi)存位于堆區(qū),而堆區(qū)的內(nèi)存是要程序員自己釋放的。

一個(gè)例子如下:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

char * retstring();
int main()
{
  char * name2;
  name2 = retstring();
  printf("%s\n",name2);
  //記住一定要用free釋放,否則會(huì)造成內(nèi)存泄露
  free(name2);
  return 0;
}

char * retstring()
{
  char * name;
  name = (char *)malloc(10); 
  strcpy(name,"張漢青");
  return name;
}

方法三:返回一個(gè)靜態(tài)局部變量。

一個(gè)例子如下:

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

char * retstring();
int main()
{
  char * name2;
  name2 = retstring();
  printf("%s\n",name2);
  return 0;
}

char * retstring()
{
  static char name[10];
  strcpy(name,"張漢青");
  return name;
}

這種方法有一個(gè)問(wèn)題: 由于采用了靜態(tài)局部變量(位于靜態(tài)區(qū),程序結(jié)束時(shí)由系統(tǒng)進(jìn)行釋放),這就導(dǎo)致,如果多次調(diào)用這個(gè)函數(shù),下一次調(diào)用會(huì)將上一次調(diào)用的結(jié)果覆蓋掉。

C語(yǔ)言中的庫(kù)函數(shù),tmpnam()函數(shù)、getenv()函數(shù)等應(yīng)該都是采用的這種方法,這也就是為什么,使用這樣的函數(shù)的時(shí)候應(yīng)該立即將返回結(jié)果拷貝一份的原因。

方法四: 使用全局變量。

一個(gè)例子如下:

char  g_s[100]; 
char*  fun() 
{ 
    strcpy(g_s,  "abc "); 
    return  s; 
} 

就寫到這里啦,希望對(duì)你有所幫助。。有錯(cuò)誤的地方還請(qǐng)指正,謝謝~~

相關(guān)文章

  • C++讀取文件的四種方式總結(jié)

    C++讀取文件的四種方式總結(jié)

    C++可以根據(jù)不同的目的來(lái)選取文件的讀取方式,C++中有四種常見(jiàn)的讀取方式,本文主要介紹了這四種方法的具體實(shí)現(xiàn),需要的可以參考一下
    2023-04-04
  • C++實(shí)現(xiàn)LeetCode(152.求最大子數(shù)組乘積)

    C++實(shí)現(xiàn)LeetCode(152.求最大子數(shù)組乘積)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(152.求最大子數(shù)組乘積),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C語(yǔ)言中文件常見(jiàn)操作的示例詳解

    C語(yǔ)言中文件常見(jiàn)操作的示例詳解

    FILE為C語(yǔ)言提供的文件類型,它是一個(gè)結(jié)構(gòu)體類型,用于存放文件的相關(guān)信息。本文主要為大家介紹下C語(yǔ)言中幾個(gè)常見(jiàn)的文件操作的實(shí)現(xiàn),需要的可以參考一下
    2022-12-12
  • C語(yǔ)言運(yùn)算符的優(yōu)先級(jí)和結(jié)合性實(shí)例詳解

    C語(yǔ)言運(yùn)算符的優(yōu)先級(jí)和結(jié)合性實(shí)例詳解

    本文主要介紹C語(yǔ)言運(yùn)算符的知識(shí),這里對(duì)運(yùn)算符的優(yōu)先級(jí)和結(jié)合性做出了詳解,并附實(shí)例代碼,希望能幫助有需要的小伙伴
    2016-07-07
  • C++超詳細(xì)分析順序表

    C++超詳細(xì)分析順序表

    程序中經(jīng)常需要將一組數(shù)據(jù)元素作為整體管理和使用,需要?jiǎng)?chuàng)建這種元素組,用變量記錄它們,傳進(jìn)傳出函數(shù)等。一組數(shù)據(jù)中包含的元素個(gè)數(shù)可能發(fā)生變化,順序表則是將元素順序地存放在一塊連續(xù)的存儲(chǔ)區(qū)里,元素間的順序關(guān)系由它們的存儲(chǔ)順序自然表示
    2022-03-03
  • C語(yǔ)言中隱藏結(jié)構(gòu)體的細(xì)節(jié)

    C語(yǔ)言中隱藏結(jié)構(gòu)體的細(xì)節(jié)

    以筆者粗淺的認(rèn)識(shí),有兩種最常用的方法,可以實(shí)現(xiàn)庫(kù)內(nèi)結(jié)構(gòu)體定義的隱藏:接口函數(shù)形參使用結(jié)構(gòu)體指針,接口函數(shù)形參使用句柄。
    2017-05-05
  • c++中拷貝構(gòu)造函數(shù)的參數(shù)類型必須是引用

    c++中拷貝構(gòu)造函數(shù)的參數(shù)類型必須是引用

    如果拷貝構(gòu)造函數(shù)中的參數(shù)不是一個(gè)引用,即形如CClass(const CClass c_class),那么就相當(dāng)于采用了傳值的方式(pass-by-value),而傳值的方式會(huì)調(diào)用該類的拷貝構(gòu)造函數(shù),從而造成無(wú)窮遞歸地調(diào)用拷貝構(gòu)造函數(shù)。因此拷貝構(gòu)造函數(shù)的參數(shù)必須是一個(gè)引用
    2013-07-07
  • C語(yǔ)言簡(jiǎn)明講解歸并排序的應(yīng)用

    C語(yǔ)言簡(jiǎn)明講解歸并排序的應(yīng)用

    這篇文章主要介紹了 c語(yǔ)言排序之歸并排序,歸并就是把兩個(gè)或多個(gè)序列合并,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-05-05
  • 詳解C++模擬實(shí)現(xiàn)priority_queue(仿函數(shù))

    詳解C++模擬實(shí)現(xiàn)priority_queue(仿函數(shù))

    本文主要介紹了關(guān)于C++中優(yōu)先級(jí)隊(duì)列的模擬實(shí)現(xiàn),以及仿函數(shù)的使用,優(yōu)先級(jí)隊(duì)列是一種容器適配器,其第一個(gè)元素總是最大的,仿函數(shù)本質(zhì)是一個(gè)類,重載了operator(),可改變比較邏輯,同時(shí),文中還介紹了如何進(jìn)行類的比較,如日期類或其指針的比較,以及庫(kù)中sort函數(shù)的使用方法
    2024-10-10
  • C語(yǔ)言直接插入排序算法

    C語(yǔ)言直接插入排序算法

    大家好,本篇文章主要講的是C語(yǔ)言直接插入排序算法,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2022-01-01

最新評(píng)論