您好,登錄后才能下訂單哦!
這篇文章主要介紹了C語言中內存函數有哪些,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。
void * memcpy ( void * destination, const void * source, size_t num );
dest復制src中num
個字節
的數據。
模擬實現memcpy
void * my_memcpy ( void * dst, const void * src, size_t count) { void * ret = dst; while (count--) { *(char *)dst = *(char *)src; dst = (char *)dst + 1; src = (char *)src + 1; } return(ret); }
·如果dst 和src指向同一個數組會發生什么?
int main() { int arr1[10] = { 1,2,3,4,5,6,7,8,9,0 }; // 預期結果 1 2 1 2 3 4 7 8 9 0 my_memcpy(arr1+2, arr1, 16); for (int i = 0; i < 10; i++) { printf("%d ", arr1[i]); } }
實際為 1 2 1 2 1 2 7 8 9 0
因為到5 6 的時候3 4被改成了1 2 ,5 6也就被改成1 2。
也就是說被復制的元素在復制前被改變了,導致復制結果失敗。
如果是這樣指向同一個數組呢?
int main() { int arr1[10] = { 1,2,3,4,5,6,7,8,9,0 }; my_memcpy(arr1, arr1+2, 16); for (int i = 0; i < 10; i++) { printf("%d ", arr1[i]); } }
復制結果沒有問題。
對于這種情況,c語言有一個更強大的函數memmove
.
void * memmove( void * destination, const void * source, size_t num );
與memcpy的功能一樣,但是memmove可以指向同一塊空間。
模擬實現memmove
**void* my_memmove(void* dest, void* src, size_t num) { char* ret = dest; //如果指向同一塊空間 判斷地址大小,避免數據在被復制前被改變 if ( (char*)dest-(char*)src< 0){ while (num) { *((char*)dest)++ = *((char*)src)++; num--; } } else { while(num--){ *((char*)dest+num) = *((char*)src+num); } } return ret; }
int memcmp ( const void * ptr1, const void * ptr2, size_t num );
從ptr1和ptr2的位置開始比較num個字節,當兩個字節數據不同時就會返回。
ptr1>ptr2 返回值>0;
ptr1=ptr2 返回值=0;
ptr1<ptr2 返回值<0;
感謝你能夠認真閱讀完這篇文章,希望小編分享的“C語言中內存函數有哪些”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。