本篇文章主要介绍了C语言中四种内存函数的使用,话不多说,正文开始。
注:这四个函数引用时我们都需要用到 #include<string.h>
一.memcpy的使用和模拟
void* memcpy(void* destination,const void* source,size_t num);
1.memcpy是内存拷贝函数,使用函数时我们需要传递三个参数,从source的位置复制num个字节的数据到destination指向的内存位置。
2.这个函数在遇到 '\0' 的时候并不会停下来。
3.在函数的使用中如果destination和source的位置有任何重叠的话,其结果是未定义的。所以我们在使用这个函数时要注意destination和source这两个参数是否有重叠。
不妨我们自己模拟实现一下这个函数:
void* my_memcpy(void* dest, const void* source, size_t num)
{
void* a = dest;
while (num--)
{
*(char*)dest = *(char*)source;
dest=(char*)dest+1;
source=(char*)source+1;
}
return a;
}
由于此函数是要复制num个字节的数据,我们便可以将void* 类型的参数强制转换成char* 类型,从而实现每个字节的复制。
二.memmove的使用与模拟
void* memmove (void* destination,const void* source,size_t num)
1.memmove函数的使用方法与memcpy大致相同,唯一的区别为memmove函数中destination参数与source参数是可以重叠的。
2.所以我们在遇见源空间与目标空间重叠时,便可以使用memmove函数。
下面为memmove的模拟实现:
void* my_memmove(void* dest, const void* sour, size_t num)
{
assert(dest && sour);
void* str = dest;
size_t a = 0;
a = (char*)dest - (char*)sour;
if ((char*)dest >= (char*)sour)
{
(char*)dest = (char*)dest + num - 1;
while (num--)
{
*(char*)dest = *((char*)dest - a);
dest = (char*)dest - 1;
}
}
else
{
while (num--)
{
*(char*)dest = *(char*)sour;
dest = (char*)dest + 1;
sour = (char*)sour + 1;
}
}
return str;
}
注:当目标空间地址大于源空间时,为了防止内容被修改导致拷贝出错,需要从后向前拷贝。
三.memset函数的使用
void* memset(void* ptr,int value,size_t num);
1.memset函数是用来设置内存的,可以将内存中的值以字节为单位设置成想要的内容
#include<stdio.h>
#include<string.h>
int main()
{
char str[] = "hellow world";
memset(str,'a', 7);
printf(str);
return 0;
}
如图所示,虽然第二个参数是int类型,但该函数使用此值的无符号字符转换填充内存块。
四.memcmp函数的使用
int memcmp(const void* ptr1,const void* ptr2,size_t num);
1.memcmp是来比较从ptr1和ptr2指针指向的位置向后num个字节的大小。
2.memcmp返回值为int类型如下图所示:
举个例子:
如图所示,b>a,函数返回值为-1,说明str1小于str2。该函数比较的是字节,如果字节相等,则往后一位进行比较大小,直到在num个字节前可以比较出大小,如果num个字节前未比较出大小,则相等。
以上便是此篇文章全部内容,求三连。