深度解析三個(gè)常見的C語言內(nèi)存函數(shù)
1.memcpy函數(shù)(內(nèi)存拷貝函數(shù))
函數(shù)介紹
1.memcpy函數(shù)的作用:從source的位置開始向后復(fù)制num個(gè)字節(jié)的數(shù)據(jù)到destination的內(nèi)存位置。 可以拷貝字符數(shù)組,整型數(shù)組,結(jié)構(gòu)體等等,所以參數(shù)是void* 的指針;
2.這個(gè)函數(shù)在遇到 '\0' 的時(shí)候并不會(huì)停下來。(注意)
3.memcpy函數(shù)的局限:如果source和destination有任何的重疊,復(fù)制的結(jié)果都是未定義的。memcpy函數(shù)拷貝不重疊的內(nèi)存的拷貝。
4.拷貝結(jié)束,返回目標(biāo)空間的起始地址。
使用舉例:
memcpy的模擬實(shí)現(xiàn):
void* memcpy(void* dst, const void* src, size_t count) { void* ret = dst; assert(dst); assert(src); while (count--) { *(char*)dst = *(char*)src; dst = (char*)dst + 1; src = (char*)src + 1; } return(ret); }
就是將源內(nèi)容一個(gè)一個(gè)字節(jié)的拷貝到目標(biāo)空間去,所以強(qiáng)制類型轉(zhuǎn)換成char*;
2.memmove函數(shù)(內(nèi)存移動(dòng)函數(shù))
函數(shù)介紹
memcpy和memmove函數(shù)的用法一樣;作用有所差別;
1.memmove函數(shù)不僅可以拷貝不重疊的內(nèi)存,而且可以拷貝重疊的內(nèi)存。
2.和memcpy的差別就是memmove函數(shù)處理的源內(nèi)存塊和目標(biāo)內(nèi)存塊是可以重疊的。
3.如果源空間和目標(biāo)空間出現(xiàn)重疊,就得使用memmove函數(shù)處理。
memmove的使用示例
當(dāng)memmove函數(shù)用來拷貝重疊內(nèi)存
memmove函數(shù)的模擬實(shí)現(xiàn)
void* memmove(void* dst, const void* src, size_t count) { void* ret = dst; if (dst <= src || (char*)dst >= ((char*)src + count)) { while (count--) { *(char*)dst = *(char*)src; dst = (char*)dst + 1; src = (char*)src + 1; } } else { dst = (char*)dst + count - 1; src = (char*)src + count - 1; while (count--) { *(char*)dst = *(char*)src; dst = (char*)dst - 1; src = (char*)src - 1; } } return(ret); }
解析:
例如
將arr[]={1,2,3,4,5,6,7,8,9,10}中的1 2 3 4 5 放到3 4 5 6 7的位置上去,如果我們還是用前面memcpy的思想
第一步:把1放到3上去,變?yōu)? 2 1 4 5 6 7 8 9 10
第二步:把2放到4上去,變?yōu)? 2 1 2 5 6 7 8 9 10
第三步:我們需要將3放到5上去,但是,第一步我們已經(jīng)將3改變了,所以這種思想不行;
memmove模擬實(shí)現(xiàn)思想:
3.memcmp函數(shù)(內(nèi)存比較函數(shù))
函數(shù)介紹
比較從ptr1和ptr2指針開始的num個(gè)字節(jié)
返回值如下:
使用示例代碼:
int main() { char buffer1[] = "DWgaOtP12df0"; char buffer2[] = "DWGAOTP12DF0"; int n; n = memcmp(buffer1, buffer2, sizeof(buffer1)); if (n > 0) { printf("'%s' is greater than '%s'.\n", buffer1, buffer2); } else if (n < 0) { printf("'%s' is less than '%s'.\n", buffer1, buffer2); } else { printf("'%s' is the same as '%s'.\n", buffer1, buffer2); } return 0; }
運(yùn)行結(jié)果:
到此這篇關(guān)于深度解析三個(gè)常見的C語言內(nèi)存函數(shù)的文章就介紹到這了,更多相關(guān)C語言內(nèi)存函數(shù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- C語言的字符串函數(shù),內(nèi)存函數(shù)筆記詳解
- c語言重要的字符串與內(nèi)存函數(shù)
- C語言內(nèi)存函數(shù)的使用及其模擬實(shí)現(xiàn)
- C語言詳解如何應(yīng)用模擬字符串和內(nèi)存函數(shù)
- C語言超詳細(xì)講解字符串函數(shù)和內(nèi)存函數(shù)
- C語言深入詳解四大內(nèi)存函數(shù)的使用
- C語言字符串函數(shù),字符函數(shù),內(nèi)存函數(shù)使用及模擬實(shí)現(xiàn)
- 深入了解C語言中的字符串和內(nèi)存函數(shù)
- C語言內(nèi)存函數(shù)的實(shí)現(xiàn)示例
- C語言內(nèi)存函數(shù)的具體使用
- C語言實(shí)現(xiàn)內(nèi)存函數(shù)的示例代碼
相關(guān)文章
C語言數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)字符串分割的實(shí)例
這篇文章主要介紹了C語言數(shù)據(jù)結(jié)構(gòu)實(shí)現(xiàn)字符串分割的實(shí)例的相關(guān)資料,希望通過本文能幫助到大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下2017-10-10C語言詳細(xì)分析講解多文件的程序設(shè)計(jì)
所謂的C語言多文件編程就是,將代碼實(shí)現(xiàn)模塊化。比如說一個(gè)項(xiàng)目的一項(xiàng)功能放在一個(gè)一個(gè)文件里,然后將實(shí)現(xiàn)這個(gè)功能的函數(shù)放在一個(gè)c文件<BR>2022-04-04C語言執(zhí)行時(shí),程序控制臺(tái)輸出窗口 一閃而過問題及解決
這篇文章主要介紹了C語言執(zhí)行時(shí),程序控制臺(tái)輸出窗口 一閃而過問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-11-11C++實(shí)現(xiàn)進(jìn)程間通信(IPC)的終極指南
進(jìn)程間通信(IPC,Inter-Process Communication),指至少兩個(gè)進(jìn)程或線程間傳送數(shù)據(jù)或信號(hào)的一些技術(shù)或方法,下面小編來和大家深入介紹一下C++實(shí)現(xiàn)進(jìn)程間通信(IPC)的相關(guān)方法吧2025-04-04簡要對(duì)比C語言中三個(gè)用于退出進(jìn)程的函數(shù)
這篇文章主要介紹了C語言中三個(gè)用于退出進(jìn)程的函數(shù)的對(duì)比,分別為_exit()函數(shù)和on_exit()函數(shù)以及atexit()函數(shù),需要的朋友可以參考下2015-08-08使用Objective-C獲取IPHONE手機(jī)IMSI序列號(hào)
這篇文章主要介紹了使用Objective-C獲取IPHONE手機(jī)IMSI序列號(hào)的方法以及通過IMSI序列號(hào)獲取運(yùn)營商、手機(jī)號(hào)的方法,非常的實(shí)用,有需要的小伙伴可以參考下。2015-04-04