前言
我们为什么要用内存操作函数?
内存函数,是通过访问地址的方式操作对象,因此可应用于任何类型对象,只要按照字节操作
1. memcpy
void * memcpy ( void * destination, const void * source, size_t num );
- 函数memcpy从source的位置开始向后复制num个字节的数据到destination的内存位置
- 此函数在遇到
\0
(参考字符串)时不会停下来 - 如果source和destination有任何的重叠,复制的结果都是未定义的
/* memcpy example */
#include <stdio.h>
#include <string.h>
struct {
char name[40];
int age;
} person, person_copy;
int main ()
{
char myname[] = "Pierre de Fermat";
/* using memcpy to copy string: */
memcpy ( person.name, myname, strlen(myname)+1 );
person.age = 46;
/* using memcpy to copy structure: */
memcpy ( &person_copy, &person, sizeof(person) );
printf ("person_copy: %s, %d \n", person_copy.name, person_copy.age );
return 0;
}
由上代码可知,memcpy可以将整个结构体拷贝给另一个结构体。当然也可以拷贝整个数组及其他内容
2.memmove
void * memmove ( void * destination, const void * source, size_t num );
- 与memcpy类似,差别是memmove函数处理的源内存块和目标内存块是可以重叠的
- 如果源空间和目标空间出现重叠,就得使用memmove函数处理
/* memmove example */
#include <stdio.h>
#include <string.h>
int main ()
{
char str[] = "memmove can be very useful......";
memmove (str+20,str+15,11);
puts (str);
return 0;
}
可见,对于C语言中重叠内存内存的拷贝应交给:memmove
3.memcmp
int memcmp ( const void * ptr1,
const void * ptr2,
size_t num );
- 比较从ptr1和ptr2指针开始的num个字节
- 返回值如下图:
/* memcmp example */
#include <stdio.h>
#include <string.h>
int main ()
{
char buffer1[] = "DWgaOtP12df0";
char buffer2[] = "DWGAOTP12DF0";
int n;
n=memcmp ( buffer1, buffer2, sizeof(buffer1) );
if (n>0) printf ("'%s' is greater than '%s'.\n",buffer1,buffer2);
else if (n<0) printf ("'%s' is less than '%s'.\n",buffer1,buffer2);
else printf ("'%s' is the same as '%s'.\n",buffer1,buffer2);
return 0;
}
此处比较字符对应的ASCII码值
4.memset
void * memset ( void * ptr, int value, size_t num );
- 内存设置函数,将指针ptr指向的内存块前num字节改为设定值
/* memset example */
#include <stdio.h>
#include <string.h>
int main()
{
int arr[] = { 0x10101010,0x20202020,0x30303030,0x40404040,0x50505050 };
memset(arr, 0, 20);
return 0;
}
memset执行前,arr的内存所保存值是
memset执行后,arr的内存所保存值是
如果本文对你有所帮助,请帮忙点赞+收藏,如果有任何建议请评论留言!