詳解C語(yǔ)言中的字符串拼接(堆與棧)
首先來(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ì)腳本之家的支持。
- C語(yǔ)言使用深度優(yōu)先搜索算法解決迷宮問(wèn)題(堆棧)
- C語(yǔ)言中棧和隊(duì)列實(shí)現(xiàn)表達(dá)式求值的實(shí)例
- C語(yǔ)言用棧和隊(duì)列實(shí)現(xiàn)的回文檢測(cè)功能示例
- C語(yǔ)言用棧實(shí)現(xiàn)十進(jìn)制轉(zhuǎn)換為二進(jìn)制的方法示例
- C語(yǔ)言對(duì)棧的實(shí)現(xiàn)基本操作
- C語(yǔ)言 數(shù)據(jù)結(jié)構(gòu)中棧的實(shí)現(xiàn)代碼
- 深入淺析C語(yǔ)言中堆棧和隊(duì)列
- C語(yǔ)言中棧的兩種實(shí)現(xiàn)方法
相關(guān)文章
C++實(shí)現(xiàn)LeetCode(143.鏈表重排序)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(143.鏈表重排序),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07基于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-01C++?二叉樹(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-03C語(yǔ)言中的for循環(huán)語(yǔ)句基本語(yǔ)法及使用
這篇文章主要介紹了C語(yǔ)言中的for循環(huán)語(yǔ)句基本語(yǔ)法及使用,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-06-06C++編寫(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