亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語言中的strdup()函數(shù)和其與strcpy()函數(shù)的區(qū)別

 更新時(shí)間:2015年08月25日 10:37:24   作者:chumojing  
這篇文章主要介紹了C語言中的strdup()函數(shù)和其與strcpy()函數(shù)的區(qū)別,同樣用于拷貝字符串的兩個(gè)函數(shù)的異同值得注意,需要的朋友可以參考下

頭文件:

#include <string.h>

定義函數(shù):

char * strdup(const char *s);

函數(shù)說明:strdup()會(huì)先用maolloc()配置與參數(shù)s 字符串相同的空間大小,然后將參數(shù)s 字符串的內(nèi)容復(fù)制到該內(nèi)存地址,然后把該地址返回。該地址最后可以利用free()來釋放。

返回值:返回一字符串指針,該指針指向復(fù)制后的新字符串地址。若返回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不是標(biāo)準(zhǔn)的c函數(shù),所以linux會(huì)報(bào)錯(cuò)!~
strcpy是標(biāo)準(zhǔn)的c函數(shù),在windows里報(bào)錯(cuò)是因?yàn)橹羔槢]申請(qǐng)空間吧!~
可以先strlen判斷from的大小,之后為to申請(qǐng)空間,之后再strcpy就不會(huì)報(bào)錯(cuò)了!~

strdup可以直接把要復(fù)制的內(nèi)容復(fù)制給沒有初始化的指針,因?yàn)樗鼤?huì)自動(dòng)分配空間給目的指針,使用結(jié)束
后要手動(dòng)釋放系統(tǒng)自動(dòng)分配的空間
strcpy的目的指針一定是已經(jīng)分配內(nèi)存的指針

最近在看別人編寫的c語言源代碼,很多人喜歡使用strdup來復(fù)制字符串,我覺得這個(gè)習(xí)慣不好,因?yàn)槿绻胧棺约旱某绦蛞浦残愿玫脑挘?br /> 就忘記有這個(gè)函數(shù)吧。我否定它的主要原因是:
1)用strdup函數(shù)的時(shí)候,往往我們會(huì)忘記內(nèi)存的釋放,可能的原因是對(duì)于C庫函數(shù)的了解不夠,畢竟是其他模塊分配內(nèi)存,自己模塊釋放它。
2) 在不同的平臺(tái)上,我們對(duì)于strdup內(nèi)存分配的函數(shù)可能采用不同的方法,比如在某些c庫中用malloc來分配,而在某些c++庫中,用new來分配 (因?yàn)閏++庫可能重寫了相關(guān)的c庫代碼)。所以對(duì)使用者在釋放它的時(shí)候產(chǎn)生了很大的疑惑,是用free還是用delete[]來釋放所分配的內(nèi)存呢?! 如果我們主管臆斷,用free來釋放它,操作未知??赡芄ぷ髡?,可能是部分內(nèi)存泄漏,也可能是程序崩潰。自己程序的正確性依賴于編譯器,很不爽吧!

我覺得,在模塊中,除非萬不得已自己分配的內(nèi)存需要其他模塊釋放,否則應(yīng)該自產(chǎn)自銷,盡量避模塊之間的這種耦合性,減少內(nèi)存泄漏的因素。
那么讀者可能會(huì)問,如果字符串復(fù)制經(jīng)常用到,類似于下面的一個(gè)代碼

char *dest = malloc( strlen( src ) + 1 );
assert( dest != NULL );
strcpy( dest, src );

經(jīng)常要被使用,寫3行代碼比較羅嗦,那么不妨使用宏來搞定它吧。這樣做的好處是確定了內(nèi)存是用malloc分配的,移植性好多了,難道不是嗎?!此外,自己定義的宏,分配內(nèi)存后要釋放,總不會(huì)忘記吧

相關(guān)文章

  • C++設(shè)計(jì)模式之訪問者模式

    C++設(shè)計(jì)模式之訪問者模式

    這篇文章主要介紹了C++設(shè)計(jì)模式之訪問者模式,本文講解了什么是訪問者模式、訪問者模式的UML類圖、訪問者模式的實(shí)現(xiàn)代碼等內(nèi)容,需要的朋友可以參考下
    2014-10-10
  • C++實(shí)現(xiàn)LeetCode(36.驗(yàn)證數(shù)獨(dú))

    C++實(shí)現(xiàn)LeetCode(36.驗(yàn)證數(shù)獨(dú))

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(36.驗(yàn)證數(shù)獨(dú)),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++內(nèi)存管理詳細(xì)解析

    C++內(nèi)存管理詳細(xì)解析

    這篇文章主要給大家分享的是C++內(nèi)存管理的詳細(xì)內(nèi)容學(xué)習(xí),下面文章圍繞C++內(nèi)存管理的相關(guān)資料展開具體學(xué)習(xí)內(nèi)容,需要的朋友可以參考一下,希望對(duì)你有所幫助
    2021-11-11
  • 詳解C++11強(qiáng)類型枚舉

    詳解C++11強(qiáng)類型枚舉

    這篇文章主要介紹了C++11強(qiáng)類型枚舉的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)c++11,感興趣的朋友可以了解下
    2020-08-08
  • 如何實(shí)現(xiàn)在C++中調(diào)用C函數(shù)

    如何實(shí)現(xiàn)在C++中調(diào)用C函數(shù)

    這篇文章主要介紹了如何實(shí)現(xiàn)在C++中調(diào)用C函數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • 淺談mwArray和一般數(shù)組的區(qū)別

    淺談mwArray和一般數(shù)組的區(qū)別

    下面小編就為大家?guī)硪黄獪\談mwArray和一般數(shù)組的區(qū)別。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2016-12-12
  • C++基礎(chǔ)教程之指針拷貝詳解

    C++基礎(chǔ)教程之指針拷貝詳解

    這篇文章主要介紹了C++基礎(chǔ)教程之指針拷貝詳解的相關(guān)資料,需要的朋友可以參考下
    2017-01-01
  • 深入VC回調(diào)函數(shù)的使用詳解

    深入VC回調(diào)函數(shù)的使用詳解

    本篇文章是對(duì)VC回調(diào)函數(shù)的使用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C++實(shí)現(xiàn)LeetCode(94.二叉樹的中序遍歷)

    C++實(shí)現(xiàn)LeetCode(94.二叉樹的中序遍歷)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(94.二叉樹的中序遍歷),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • 淺析C語言中assert的用法

    淺析C語言中assert的用法

    以下是對(duì)C語言中assert的使用方法進(jìn)行了介紹,需要的朋友可以參考下
    2013-07-07

最新評(píng)論