您好,登录后才能下订单哦!
这篇文章主要介绍了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进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。