C語言中的strdup()函數(shù)和其與strcpy()函數(shù)的區(qū)別
頭文件:
#include <string.h>
定義函數(shù):
char * strdup(const char *s);
函數(shù)說明:strdup()會先用maolloc()配置與參數(shù)s 字符串相同的空間大小,然后將參數(shù)s 字符串的內(nèi)容復制到該內(nèi)存地址,然后把該地址返回。該地址最后可以利用free()來釋放。
返回值:返回一字符串指針,該指針指向復制后的新字符串地址。若返回NULL 表示內(nèi)存不足。
范例
#include <string.h> main(){ char a[] = "strdup"; char *b; b = strdup(a); printf("b[]=\"%s\"\n", b); }
執(zhí)行結(jié)果:
b[]="strdup"
strdup()函數(shù)與strcpy()函數(shù)的區(qū)別
strdup不是標準的c函數(shù),所以linux會報錯!~
strcpy是標準的c函數(shù),在windows里報錯是因為指針沒申請空間吧!~
可以先strlen判斷from的大小,之后為to申請空間,之后再strcpy就不會報錯了!~
strdup可以直接把要復制的內(nèi)容復制給沒有初始化的指針,因為它會自動分配空間給目的指針,使用結(jié)束
后要手動釋放系統(tǒng)自動分配的空間
strcpy的目的指針一定是已經(jīng)分配內(nèi)存的指針
最近在看別人編寫的c語言源代碼,很多人喜歡使用strdup來復制字符串,我覺得這個習慣不好,因為如果想使自己的程序移植性更好的話,
就忘記有這個函數(shù)吧。我否定它的主要原因是:
1)用strdup函數(shù)的時候,往往我們會忘記內(nèi)存的釋放,可能的原因是對于C庫函數(shù)的了解不夠,畢竟是其他模塊分配內(nèi)存,自己模塊釋放它。
2) 在不同的平臺上,我們對于strdup內(nèi)存分配的函數(shù)可能采用不同的方法,比如在某些c庫中用malloc來分配,而在某些c++庫中,用new來分配 (因為c++庫可能重寫了相關的c庫代碼)。所以對使用者在釋放它的時候產(chǎn)生了很大的疑惑,是用free還是用delete[]來釋放所分配的內(nèi)存呢?! 如果我們主管臆斷,用free來釋放它,操作未知??赡芄ぷ髡#赡苁遣糠謨?nèi)存泄漏,也可能是程序崩潰。自己程序的正確性依賴于編譯器,很不爽吧!
我覺得,在模塊中,除非萬不得已自己分配的內(nèi)存需要其他模塊釋放,否則應該自產(chǎn)自銷,盡量避模塊之間的這種耦合性,減少內(nèi)存泄漏的因素。
那么讀者可能會問,如果字符串復制經(jīng)常用到,類似于下面的一個代碼
char *dest = malloc( strlen( src ) + 1 ); assert( dest != NULL ); strcpy( dest, src );
經(jīng)常要被使用,寫3行代碼比較羅嗦,那么不妨使用宏來搞定它吧。這樣做的好處是確定了內(nèi)存是用malloc分配的,移植性好多了,難道不是嗎?!此外,自己定義的宏,分配內(nèi)存后要釋放,總不會忘記吧
- 詳解C語言中strcpy()函數(shù)與strncpy()函數(shù)的使用
- C語言中字符串常用函數(shù)strcat與strcpy的用法介紹
- C語言 strcpy和memcpy區(qū)別詳細介紹
- C語言不使用strcpy函數(shù)如何實現(xiàn)字符串復制功能
- 徹底掌握C語言strcpy函數(shù)的用法
- 詳解c語言中的 strcpy和strncpy字符串函數(shù)使用
- C語言的strcpy函數(shù)你了解嗎
- C語言strcpy庫函數(shù)詳解
- C語言中strcpy()函數(shù)的具體實現(xiàn)及注意事項
- C語言庫函數(shù)strcpy的使用及模擬實現(xiàn)
相關文章
C++實現(xiàn)LeetCode(36.驗證數(shù)獨)
這篇文章主要介紹了C++實現(xiàn)LeetCode(36.驗證數(shù)獨),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07如何實現(xiàn)在C++中調(diào)用C函數(shù)
這篇文章主要介紹了如何實現(xiàn)在C++中調(diào)用C函數(shù)問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08C++實現(xiàn)LeetCode(94.二叉樹的中序遍歷)
這篇文章主要介紹了C++實現(xiàn)LeetCode(94.二叉樹的中序遍歷),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07