C/C++字符串函數(shù)之復(fù)制函數(shù)詳解
突然發(fā)現(xiàn)對(duì)字符串函數(shù)缺乏系統(tǒng)的了解,所以花了一點(diǎn)時(shí)間專門整理下,在此記錄之,以方便自己及有需要的人使用。
C/C++字符串函數(shù)的頭文件:string.h
復(fù)制函數(shù)主要有4個(gè),如下:
1、char * strcpy(char* destination,const char * source); 2、char* strncpy(char* destination,const char* source,size_t num); 3、void * memcpy(void* destination,const void* source,size_t num); 4、void * memmove(void* destination,const void* source,size_t num);
功能及用法說(shuō)明:
1、strcpy:將由source指針指示的C 字符串(包括結(jié)尾字符)復(fù)制到destination指針指示的區(qū)域中。該函數(shù)不允許source和destination的區(qū)域有重疊,同時(shí),為了避免溢出,destination區(qū)域應(yīng)該至少和source區(qū)域一樣大。
2、strncpy:復(fù)制source的前num字符到destination。如果遇到null字符('\0'),且還沒(méi)有到num個(gè)字符時(shí),就用(num - n)(n是遇到null字符前已經(jīng)有的非null字符個(gè)數(shù))個(gè)null字符附加到destination。注意:并不是添加到destination的最后,而是緊跟著由source中復(fù)制而來(lái)的字符后面。下面舉例說(shuō)明:
char des[] = "Hello,i am!"; char source[] = "abc\0def"; strncpy(des,source,5);
此時(shí),des區(qū)域是這樣的:a,b,c,\0,\0,i,空格,a,m,!
\0,\0并不是添加在!的后面。
這里,需要注意strcpy僅僅復(fù)制到null字符就結(jié)束了。
3、memcpy:將source區(qū)域的前num個(gè)字符復(fù)制到destination中。該函數(shù)不檢查null字符(即將null字符當(dāng)作普通字符處理),意味著將復(fù)制num個(gè)字符才結(jié)束。該函數(shù)不會(huì)額外地引入null字符,即如果num個(gè)字符中沒(méi)有null字符,那么destination中相應(yīng)字符序列中也沒(méi)有null字符。同strcpy的區(qū)別:允許將source中null字符后面的字符也復(fù)制到destination中,而strcpy和strncpy則不可以。
4、memmove:同memcpy完成同樣的功能,區(qū)別是,memmove允許destination和source的區(qū)域有重疊。而其他三個(gè)函數(shù)不允許。
例子:
char str[] = "This is a test!"; memmove(str+2,str+10,4);
此時(shí),str變成:Thtests a test!
以上這篇C/C++字符串函數(shù)之復(fù)制函數(shù)詳解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
C++中function的實(shí)現(xiàn)原理詳解
類模版std::function是一種通用、多態(tài)的函數(shù)封裝。function的實(shí)例可以對(duì)任何可以調(diào)用的目標(biāo)實(shí)體進(jìn)行存儲(chǔ)、復(fù)制、和調(diào)用操作。本文主要聊聊它的實(shí)現(xiàn)原理,需要的可以參考一下2022-12-12
C語(yǔ)言算法練習(xí)之折半查找的實(shí)現(xiàn)
二分查找法(也叫折半查找)其本質(zhì)是分治算法的一種。這篇文章主要介紹了如何利用C語(yǔ)言實(shí)現(xiàn)折半查找,感興趣的小伙伴可以學(xué)習(xí)一下2022-05-05
C語(yǔ)言二叉樹(shù)常見(jiàn)操作詳解【前序,中序,后序,層次遍歷及非遞歸查找,統(tǒng)計(jì)個(gè)數(shù),比較,求深度】
這篇文章主要介紹了C語(yǔ)言二叉樹(shù)常見(jiàn)操作,結(jié)合實(shí)例形式詳細(xì)分析了基于C語(yǔ)言的二叉樹(shù)前序,中序,后序,層次遍歷及非遞歸查找,統(tǒng)計(jì)個(gè)數(shù),比較,求深度等相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下2018-04-04
詳解在C++中顯式默認(rèn)設(shè)置的函數(shù)和已刪除的函數(shù)的方法
這篇文章主要介紹了在C++中顯式默認(rèn)設(shè)置的函數(shù)和已刪除的函數(shù)的方法,文中講到了C++11標(biāo)準(zhǔn)中的新特性,需要的朋友可以參考下2016-01-01
C++多字節(jié)字符與寬字節(jié)字符相互轉(zhuǎn)換
最近在C++編程中經(jīng)常遇到需要多字節(jié)字符與寬字節(jié)字符相互轉(zhuǎn)換的問(wèn)題,自己寫了一個(gè)類來(lái)封裝wchar_t與char類型間的轉(zhuǎn)換2012-11-11

