【C语言】内存函数
1.memcpy
void * memcpy ( void * destination, const void * source, size_t num );
1.从source的位置开始向后复制num个字节的数据到destination的内存位置
2.num是字节数
如果有两个整形数组,arr2想要把arr的前五个元素拷贝到自身空间里,使用strcpy行不通,因为strcpy适用于字符串,可以使用memcpy解决。
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
int arr2[10] = { 0 };
int i = 0;
memcpy(arr2, arr, 20); //20是字节数,整形占4个字节,所以会拷贝5个整形
for (i = 0; i < 10; i++) {
printf("%d ", arr2[i]);
}
拷贝了前5个元素
代码实现memcpy
memcpy的形参时void*,void*的指针是什么类型的地址都可以接收。
//每次都拷贝一个字节
void* my_memcpy(void* dest, const void* src, size_t num) {
assert(dest && src);
void* ret = dest;
while (num--) {
*(char*)dest = *(char*)src;
dest = (char*)dest + 1;
src=(char*)src + 1;
}
return ret;
}
2.memmove
还是上面这个代码,如果我想要把arr的前5个元素(1,2,3,4,5)拷贝到(3,4,5,6,7)的位置上面,使用自己写的my_memcpy代码行得通吗?
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
my_memcpy(arr+2, arr, 20);
通过调试,发现后面的值被覆盖了,从而失败了。
memcpy函数应该拷贝不重叠的内存.
上述情况它做不到,memmove函数能够解决内存重叠问题。
void * memmove (void * destination, const void * source, size_t num );
注意事项:
1.memmove 和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。
2.如果源空间和目标空间出现重叠,就得使用memmove函数处理。
原理说明:
代码实现memmove
void* my_memmove(void* dest, const void* src, size_t num) {
void* ret = dest;
if (dest < src) {
while (num--) {
*(char*)dest = *(char*)src;
dest = (char*)dest + 1;
src = (char*)src + 1;
}
}
else{
while (num--) {
*((char*)dest + num) = *((char*)src + num);
}
}
return ret;
}
3.memcmp
int memcmp ( const void * ptr1, const void * ptr2, size_t num );
把存储区 str1 和存储区 str2 的前 n 个字节进行比较
参数
str1 -- 指向内存块的指针。
str2 -- 指向内存块的指针。
n -- 要被比较的字节数。
返回值
如果返回值 < 0,则表示 str1 小于 str2。
如果返回值 > 0,则表示 str1 大于 str2。
如果返回值 = 0,则表示 str1 等于 str2。
int arr[10] = { 1,2,3 };
int arr2[10] = { 1,4,5 };
int ret=memcmp(arr, arr2, 8); //比较前8个字节
printf("%d ", ret);
4.memset
int memcmp(const void *str1, const void *str2, size_t n)
复制字符 c(一个无符号字符)到参数 str 所指向的字符串的前 n 个字符
参数
str -- 指向要填充的内存块。
c -- 要被设置的值。该值以 int 形式传递,但是函数在填充内存块时是使用该值的无符号字符形式。
n -- 要被设置为该值的字符数。以字节为单位。
char str[50];
strcpy(str, "This is function");
puts(str);
memset(str, '$', 7);
puts(str);