之前写的字符函数都只针对字符串,而内存函数是针对内存的,不在乎内存里面是什么。
memcpy
函数介绍
void * memcpy ( void * destination, const void * source, size_t num );
函数memcpy从source的位置开始向后复制num个字节的数据到destination指向的内存位置。
这个函数在遇到’\0’ 的时候并不会停下来。
如果source和destination有任何的重叠,复制的结果都是未定义的。
int main()
{
int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
int arr2[10] = { 0 };
memcpy(arr2, arr1, 20);
int i = 0;
for (i = 0; i < 10; i++)
{
printf("%d ", arr2[i]);
}
return 0;
}
模拟实现
void* my_memcpy(void* str1, const void* str2, size_t num)
{
void* ret = str1;
assert(str1 && str2);
while (num--)
{
*(char*)str1 = *(char*)str2;
str1 = (char*)str1 + 1;
str2 = (char*)str2 + 1;
}
return ret;
}
由于memcpy函数的特性,不能拷贝内存重叠的区域,拷贝内存重叠区域可以使用memmove函数。
memmove
函数介绍
void *memmove(void *str1, const void *str2, size_t n)
从 str2 复制 n 个字符到 str1,但是在重叠内存块这方面,memmove() 是比 memcpy() 更安全的方法。如果目标区域和源区域有重叠的话,memmove() 能够保证源串在被覆盖之前将重叠区域的字节拷贝到目标区域中,复制后源区域的内容会被更改。如果目标区域与源区域没有重叠,则和 memcpy() 函数功能相同。
模拟实现
void* my_memmove(void* str1, const void* str2, size_t num)
{
void* ret = str1;
assert(str1 && str2);
if (str1 < str2)
{
while (num--)
{
*(char*)str1 = *(char*)str2;
str1 = (char*)str1 + 1;
str2 = (char*)str2 + 1;
}
}
else
{
while (num--)//进入循环刚好少1,比如拷贝5个,刚好是 +4
{
*((char*)str1 + num) = *((char*)str2 + num);
}
}
return ret;
}
memset
内存设置函数。
函数介绍
void *memset(void *str, int c, size_t n)
用于将一段内存区域设置为指定的值。
memset() 函数将指定的值 c 复制到 str 所指向的内存区域的前 n 个字节中,这可以用于将内存块清零或设置为特定值。注意是以字节为单位,而不是整型。
在一些情况下,需要快速初始化大块内存为零或者特定值,memset() 可以提供高效的实现。
memcmp
内存比较函数
int memcmp(const void *str1, const void *str2, size_t n)
str1 – 指向内存块的指针。
str2 – 指向内存块的指针。
n – 要被比较的字节数。
从参数地址开始比较,按照字节单位向后比较。
如果返回值 < 0,则表示 str1 小于 str2。
如果返回值 > 0,则表示 str1 大于 str2。
如果返回值 = 0,则表示 str1 等于 str2。