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

詳解C語(yǔ)言中的字符串拼接(堆與棧)

 更新時(shí)間:2017年01月11日 15:18:11   作者:PHPor  
這篇文章主要介紹了C語(yǔ)言中字符串拼接(堆與棧)的相關(guān)資料,文中通過(guò)一段示例代碼詳細(xì)介紹了關(guān)于C語(yǔ)言中的字符串拼接問(wèn)題,有需要的朋友可以參考借鑒,下面來(lái)一起看看吧。

首先來(lái)看一個(gè)demo:

int do_sth(int type) {
  char *errstr;
  
  switch(type) {
  case 1:
    errstr = "Error";break
  case 2:
    errstr = "Warn";break
  case 3:
    errstr = "Info";break
  case 4:
    errstr = "Debug";break
  default:
    return 0;
  }
 
  if (...) {..}
  if (...) {
    ..;
    fprintf(stdout, "%s %s", errstr, ...);
    return 1;
  }
  if (...) { return 1;}
  if (...) {
    fprintf(stderr, "%s %s", errstr, ...);
  }
  ...
  return 0;
}

問(wèn)題: 如何在errstr信息前面添加一個(gè)HOSTNAME 環(huán)境變量信息?

考慮到errstr有可能寫(xiě)到標(biāo)準(zhǔn)錯(cuò)誤,也有可能寫(xiě)到標(biāo)準(zhǔn)輸出,也有可能根本就不輸出,所以,提前輸出HOSTNAME 信息顯然不合適

考慮到引用errstr的地方確實(shí)不少,最好一開(kāi)始就拼接HOSTNAME到該errstr 上面去,那么如何拼接呢?

如果是在腳本語(yǔ)言或者帶有g(shù)c的語(yǔ)言中,完全可以直接在errstr變量前面拼接那個(gè)動(dòng)態(tài)獲取到的環(huán)境變量,如:

errstr=getenv("HOSTNAME") + errstr ;

但是c中卻不能這樣,為什么呢?字符串拼接的函數(shù)不是有的嗎,如:strcat;

事實(shí)卻并非如此簡(jiǎn)單,為什么呢?

上面的errstr變量是存儲(chǔ)在棧上的,不需要考慮free的問(wèn)題,原作者考慮到后續(xù)一大堆復(fù)雜的if分支,如果把errstr放在堆上,處處要考慮是不是該把errstr free掉,得死多少腦細(xì)胞啊!

對(duì)于HOSTNAME是個(gè)運(yùn)行時(shí)的信息,顯然沒(méi)法放到棧上,如果非要和errstr拼接起來(lái)的話,errstr必須在堆上,即要?jiǎng)討B(tài)的malloc,由此可見(jiàn),對(duì)于腳本語(yǔ)言來(lái)講,一個(gè)非常簡(jiǎn)單的邏輯,在C中卻如此的麻煩

解決辦法:

為了既不需要free,又能拼接字符串,可以定義一個(gè)字符數(shù)組,如: errstr[255],然后,把需要的信息加進(jìn)去;為了避免信息太多而不小心越界,可以使用snprintf函數(shù),自動(dòng)丟棄超長(zhǎng)的部分

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

  • C++實(shí)現(xiàn)LeetCode(143.鏈表重排序)

    C++實(shí)現(xiàn)LeetCode(143.鏈表重排序)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(143.鏈表重排序),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • OpenCV如何提取圖片中曲線

    OpenCV如何提取圖片中曲線

    這篇文章主要為大家詳細(xì)介紹了OpenCV如何提取圖片中曲線,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • 基于C語(yǔ)言實(shí)現(xiàn)圖書(shū)管理信息系統(tǒng)設(shè)計(jì)

    基于C語(yǔ)言實(shí)現(xiàn)圖書(shū)管理信息系統(tǒng)設(shè)計(jì)

    這篇文章主要為大家詳細(xì)介紹了基于C語(yǔ)言實(shí)現(xiàn)圖書(shū)管理信息系統(tǒng)設(shè)計(jì)與實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • c語(yǔ)言快速排序算法示例代碼分享

    c語(yǔ)言快速排序算法示例代碼分享

    快速排序使用分治法(Divide and conquer)策略來(lái)把一個(gè)串行(list)分為兩個(gè)子串行(sub-lists)
    2014-02-02
  • C語(yǔ)言二叉樹(shù)的遍歷示例介紹

    C語(yǔ)言二叉樹(shù)的遍歷示例介紹

    大家好,本篇文章主要講的是C語(yǔ)言二叉樹(shù)的遍歷示例介紹,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽
    2022-01-01
  • C++?二叉樹(shù)的實(shí)現(xiàn)超詳細(xì)解析

    C++?二叉樹(shù)的實(shí)現(xiàn)超詳細(xì)解析

    二叉樹(shù)可以簡(jiǎn)單理解為對(duì)于一個(gè)節(jié)點(diǎn)來(lái)說(shuō),最多擁有一個(gè)上級(jí)節(jié)點(diǎn),同時(shí)最多具備左右兩個(gè)下級(jí)節(jié)點(diǎn)的數(shù)據(jù)結(jié)構(gòu)。本文將詳細(xì)介紹一下C++中二叉樹(shù)的實(shí)現(xiàn)和遍歷,需要的可以參考一下
    2022-03-03
  • C語(yǔ)言中的for循環(huán)語(yǔ)句基本語(yǔ)法及使用

    C語(yǔ)言中的for循環(huán)語(yǔ)句基本語(yǔ)法及使用

    這篇文章主要介紹了C語(yǔ)言中的for循環(huán)語(yǔ)句基本語(yǔ)法及使用,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-06-06
  • c++虛函數(shù)與虛函數(shù)表原理

    c++虛函數(shù)與虛函數(shù)表原理

    這篇文章主要介紹了c++虛函數(shù)與虛函數(shù)表原理,用virtual?修飾的成員函數(shù)叫虛函數(shù),下面圍繞c++虛函數(shù)與虛函數(shù)得相關(guān)資料展開(kāi)內(nèi)容,需要的朋友可以參考一下
    2021-12-12
  • C++編寫(xiě)簡(jiǎn)易的飛機(jī)大戰(zhàn)

    C++編寫(xiě)簡(jiǎn)易的飛機(jī)大戰(zhàn)

    一款自己設(shè)計(jì)的飛機(jī)小游戲,本程序于運(yùn)行環(huán)境WINDOWS XP系統(tǒng),采用C++語(yǔ)言編寫(xiě)。游戲具有得分排名榜,而且在游戲完成后可以提交得分到網(wǎng)絡(luò)上的世界排名榜中。
    2015-08-08
  • 利用C++實(shí)現(xiàn)?然連接操作算法

    利用C++實(shí)現(xiàn)?然連接操作算法

    這篇文章主要介紹了利用C++實(shí)現(xiàn)?然連接操作算法,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定參考價(jià)值,需要的小伙伴可以參考一下
    2022-08-08

最新評(píng)論