文章目录
-
- 引入
- 内存函数类型
- memcpy使⽤和模拟实现
- memmove使⽤和模拟实现
- memset函数的使⽤
- memcmp函数的使⽤
引入
我们见过库函数printf、见过字符函数,接下来,我们将开启“C语言内存函数”之旅!我们一同感受C语言的魅力!要调用这些函数都需要包含<string.h>库。
内存函数类型
1. memcpy使⽤和模拟实现
2. memmove使⽤和模拟实现
3. memset函数的使⽤
4. memcmp函数的使⽤
memcpy使⽤和模拟实现
mencpy函数与strncpy对比:
相同之处:同样可以拷贝一串字符串,需要传输的参数类型相同
不同之处:mencpy函数遇到'\0'不会停下来,而strcpy函数遇到'\0'就会停下来
通过对比,我们更加了解了mencpy函数,接下来我们就来打开mencpy函数的大门!
函数memcpy从source的位置开始向后复制num个字节的数据到destination指向的内存位置。
如果source和destination有任何的重叠,复制的结果都是未定义的。
void * memcpy ( void * destination, const void * source, size_t num );//这是函数的申明
memcpy(arr2, arr1, 20);//这是函数的调用
mencpy函数的模拟:
void * memcpy ( void * dst, const void * src, size_t count)//函数申明
{
void * ret = dst;//定义一个指针存放目标字符串初始地址
assert(dst);//检测dst、src地址的有效性
assert(src);
while (count--)//设置循环,计算要copy的字符个数
{
*(char *)dst = *(char *)src;//从源字符串取出字符copy到目标字符串对应位置
dst = (char *)dst + 1;
src = (char *)src + 1;//dst、src都前进一个位置,每个循环
}
return(ret);//返回存放目标字符串初始地址
}
memmove使⽤和模拟实现
和memcpy的差别就是memmove函数处理的源内存块和⽬标内存块是可以重叠的。
如果源空间和⽬标空间出现重叠,就得使⽤memmove函数处理。
void * memmove ( void * destination, const void * source, size_t num );//menmove函数的申明
memmove(arr1+2, arr1, 20);//menmove函数的调用
memmove的模拟实现:
void * memmove ( void * dst, const void * src, size_t count)//函数申明
{
void * ret = dst;//定义一个指针存放目标字符串初始地址
if (dst = ((char *)src + count))//判断dst初始位置与src初始位置的大小,决定从前往后复制还是从后往前复制
{
while (count--)
{
*(char *)dst = *(char *)src;
dst = (char *)dst + 1;
src = (char *)src + 1;
}
}
else {
dst = (char *)dst + count - 1;
src = (char *)src + count - 1;
while (count--)
{
*(char *)dst = *(char *)src;
dst = (char *)dst - 1;
src = (char *)src - 1;
}
}
return(ret)
}
memset函数的使⽤
memset是⽤来设置内存的,将内存中的值以字节为单位设置成想要的内容。
void * memset ( void * ptr, int value, size_t num );//menset函数的申明
char str[] = "hello world";
memset (str,'x',6);//menset函数的调用
输出结果:
xxxxxxworld
memcmp函数的使⽤
⽐较从ptr1和ptr2指针指向的位置开始,向后的num个字节。
从ptr1和ptr2开始,遇到ptr1>ptr2,则返回>0的数字
从ptr1和ptr2开始,遇到ptr1<ptr2,则返回<0的数字
从ptr1和ptr2开始,没有出现以上情况,则返回=0的数字
以上为本人的个人观点,如有错误请指出!