對比C語言中memccpy()函數(shù)和memcpy()函數(shù)的用法
C語言memccpy()函數(shù):復(fù)制內(nèi)存中的內(nèi)容
頭文件:
#include <string.h>
定義函數(shù):
void * memccpy(void *dest, const void * src, int c, size_t n);
函數(shù)說明:memccpy()用來拷貝src 所指的內(nèi)存內(nèi)容前n 個字節(jié)到dest 所指的地址上。與memcpy()不同的是,memccpy()會在復(fù)制時檢查參數(shù)c 是否出現(xiàn),若是則返回dest 中值為c 的下一個字節(jié)地址。
返回值:返回指向dest 中值為c 的下一個字節(jié)指針。返回值為0 表示在src 所指內(nèi)存前n 個字節(jié)中沒有值為c的字節(jié)。
范例
#include <string.h> main(){ char a[] = "string[a]"; char b[] = "string(b)"; memccpy(a, b, 'B', sizeof(b)); printf("memccpy():%s\n", a); }
執(zhí)行結(jié)果:
memccpy():string(b)
C語言memcpy()函數(shù):復(fù)制內(nèi)存內(nèi)容(忽略\0)
頭文件:
#include <string.h>
memcpy() 用來復(fù)制內(nèi)存,其原型為:
void * memcpy ( void * dest, const void * src, size_t num );
memcpy() 會復(fù)制 src 所指的內(nèi)存內(nèi)容的前 num 個字節(jié)到 dest 所指的內(nèi)存地址上。
memcpy() 并不關(guān)心被復(fù)制的數(shù)據(jù)類型,只是逐字節(jié)地進行復(fù)制,這給函數(shù)的使用帶來了很大的靈活性,可以面向任何數(shù)據(jù)類型進行復(fù)制。
需要注意的是:
dest 指針要分配足夠的空間,也即大于等于 num 字節(jié)的空間。如果沒有分配空間,會出現(xiàn)斷錯誤。
dest 和 src 所指的內(nèi)存空間不能重疊(如果發(fā)生了重疊,使用 memmove() 會更加安全)。
與 strcpy() 不同的是,memcpy() 會完整的復(fù)制 num 個字節(jié),不會因為遇到“\0”而結(jié)束。
【返回值】返回指向 dest 的指針。注意返回的指針類型是 void,使用時一般要進行強制類型轉(zhuǎn)換。
代碼示例:
#include <stdio.h> #include <stdlib.h> #include <string.h> #define N (10) int main() { char* p1 = "abcde"; char* p2 = (char*)malloc(sizeof(char) * N); char* p3 = (char*)memcpy(p2, p1, N); printf("p2 = %s\np3 = %s\n", p2, p3); free(p2); p2 = NULL; p3 = NULL; system("pause"); return 0; }
運行結(jié)果:
p2 = abcde p3 = abcde
代碼說明:
1) 代碼首先定義p1,p2,p3三個指針,但略有不同,p1指向一個字符串字面值,給p2分配了10個字節(jié)的內(nèi)存空間。
2) 指針p3通過函數(shù)memcpy直接指向了指針p2所指向的內(nèi)存,也就是說指針p2、p3指向了同一塊內(nèi)存。然后打印p2,p3指向的內(nèi)存值,結(jié)果是相同的。
3) 最后按照好的習(xí)慣釋放p2,并把p3也置為NULL是為了防止再次訪問p3指向的內(nèi)存,導(dǎo)致野指針的發(fā)生。
相關(guān)文章
C語言sizeof與字符串處理與動態(tài)內(nèi)存分配及main函數(shù)參數(shù)詳解
這篇文章主要介紹了C語言字符串處理函數(shù)、sizeof、動態(tài)內(nèi)存分配函數(shù)、main函數(shù)參數(shù)問題,static在修飾變量的時候,如果是修飾全局變量,則跟全局變量功能一樣,通過示例代碼給大家介紹的非常詳細,需要的朋友可以參考下2022-07-07使用設(shè)計模式中的單例模式來實現(xiàn)C++的boost庫
這篇文章主要介紹了使用設(shè)計模式中的單例模式來實現(xiàn)C++的boost庫的方法,其中作者對線程安全格外強調(diào),需要的朋友可以參考下2016-03-03