strcpy和strncpy用法和區別

void *memcpy(void *dest, const void *src, int n);

功能:

      從源src所指的內存地址的起始位置開始拷貝n個字節到目標dest所指的內存地址的起始位置中。

頭文件:

      #include <string.h>

返回值:

     指向dest的指針。

 

char *strcpy(char *dest, char *src);

功能:

      把src所指由'\0'結束的字符串複製到dest所指的數組中。

頭文件:

      #include "string.h"

返回值:

      指向dest的指針。

 

char * strncpy(char *dest, char *src, size_t n);

功能:

      將字符串src中最多n個字符複製到字符數組dest中

返回值:

      指向dest的指針。

頭文件:

      #include "string.h"

 

memcpy說明:

  1.src和dest所指內存區域不能重疊,函數返回指向dest的指針。

  2.與strcpy相比,memcpy並不是遇到'\0'就結束,而是一定會拷貝完n個字節。

  3.如果目標數組destin本身已有數據,執行memcpy()後,將覆蓋原有數據(最多覆蓋n)。如果要追加數據,則每次執行memcpy後,要將目標數組地址增加到你要追加數據的地址。

  //注意,src和dest都不一定是數組,任意的可讀寫的空間均可。

 

strcpy說明:

      src和dest所指內存區域不可以重疊且dest必須有足夠的空間來容納src的字符串。  

      當src串長度>dest串長度時,程序仍會將整個src串複製到dest區域,可是dest數組已發生溢出。因此會導致dest棧空間溢出以致產生崩潰異常。如果不考慮src串的完整性,可以把dest數組最後一元素置爲NULL,從dest串長度處插入NULL截取字串。

 

strncpy說明:

      它並不像strcpy一樣只有遇到NULL才停止複製,而是多了一個條件停止,就是說如果複製到第n個字符還未遇到NULL,也一樣停止。

      如果n > dest串長度,dest棧空間溢出產生崩潰異常。

      否則:

      1)src串長度<=dest串長度,(這裏的串長度包含串尾NULL字符)

      如果n=(0, src串長度),src的前n個字符複製到dest中。但是由於沒有NULL字符,所以直接訪問dest串會發生棧溢出的異常情況。

      如果n = src串長度,與strcpy一致。

      如果n = dest串長度,[0,src串長度]處存放於desk字串,(src串長度, dest串長度]處存放NULL。

      2)src串長度>dest串長度

      如果n =dest串長度,則dest串沒有NULL字符,會導致輸出會有亂碼。如果不考慮src串複製完整性,可以將dest最後一字符置爲NULL。

      綜上,一般情況下,使用strncpy時,建議將n置爲dest串長度(除非你將多個src串都複製到dest數組,並且從dest尾部反向操作),複製完畢後,爲保險起見,將dest串最後一字符置NULL,避免發生在第2)種情況下的輸出亂碼問題。當然嘍,無論是strcpy還是strncpy,保證src串長度<dest串長度纔是最重要的。

 

 

strncpy_s:目標空間長度不夠時,會彈出assert,使copy不能正常完成,使用時需要指定源緩衝區大小。

                   _s函數只是windows提供的特有函數,功能比較強大,但是在有跨平臺需求的軟件中,不建議使用。

strncpy:拷貝你指定的個數或者碰到'\0',不驗證源緩衝區長度,可能造成越界。

memcpy:不理'\0',只拷貝你指定的個數,故strcpy可以不指定字符串長度,實現整串copy,而memcpy必定要指定長度。

 


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章