目录
1memcpy使用和模拟实现
void*memcpy(void*aaa,const void*bbb,size_t num)
- 函数memcpy从bbb的位置开始向后复制num个字节的数据到aaa指向的内存位置。
- 这个函数在遇到'\0'的时候并不会停下来。
如果aaa和bbb有任何的重叠,复制的结果都是未定义的。
#include<stdio.h>
#include<string.h>
int main()
{
int bbb[10] = { 0,1,2,3,4,5,6,7,8,9 };
int aaa[100] = { 0 };
memcpy(aaa, bbb, 20);
for (int i = 0; i < 5; i++)
printf("%d",aaa[i]);
return 0;
}
memcpy的模拟实现:
void* my_memcpy(void*aaa,const void*bbb,size_t num)
{
void *ret = aaa;
assert(aaa);
assert(bbb);
for (int i = 0; i < num; i++)
{
*(char*)aaa = *(char*)bbb;
aaa = (char*)aaa+1;
bbb = (char*)bbb+1;
}
return ret;
}
2memmove使用和模拟实现
void*memmove(void*aaa,const void*bbb,size_t num);
- 和memcpy的差别就是memmove函数处理的源内存块和目标内存块是可以重叠的。
如果源空间和目标空间出现重叠,就得使用memmove函数处理。
#include<stdio.h>
#include<string.h>
int main()
{
int data[10] = { 0,1,2,3,4,5,6,7,8,9 };
memmove(data + 2, data, 20);
for (int i = 0; i < 10; i++)
printf("%d", data[i]);
return 0;
}
结果:
0101234789
memmove的模拟实现:
void* my_memmove(void* aaa, const void* bbb, size_t num)
{
void* ret = aaa;
assert(aaa);
assert(bbb);
if (aaa<bbb || (char*)aaa>(char*)bbb + num)
{
while ( num--)
{
*(char*)aaa = *(char*)bbb;
aaa = (char*)aaa + 1;
bbb = (char*)bbb + 1;
}
}
else
{
aaa = (char*)aaa + num - 1;
bbb = (char*)bbb + num - 1;
while (num--)
{
*(char*)aaa = *(char*)bbb;
aaa = (char*)aaa - 1;
bbb = (char*)bbb - 1;
}
}
return ret;
}
3memset函数的使用
void*memset(void*aaa,int value,size_t num);
memset是用来设置内存的,将内存中的值以字节为单位设置成想要的内容,
#include<stdio.h>
#include<string.h>
int main()
{
char arr[15] = "you is a boy";
memset(arr, 'y', 6);
printf("%s", arr);
return 0;
}
输出结果:
yyyyyy a boy
4memcmp函数的使用
int memcmp(const void*aaa,const void*bbb,size_t num);
- 比较从aaa,bbb指针指向的位置开始,向后的num个字节
#include<stdio.h> #include<string.h> int main() { char arr1[] = "asddf"; char arr2[] = "asddg"; printf("%d", memcmp(arr1, arr2, 5)); return 0; }