前言
上篇中我们介绍了一些常见的字符和字符串函数,这次我们介绍一些常见的内存函数。
memcpy()函数
作用:memcpy()函数作用于拷贝内存中的不重复数据。 形式:void * memcpy ( void * destination, const void * source, size_t num ); 解释:memcpy函数将src的count字节复制到dest。如果源和目标重叠,此函数不确保在覆盖之前复制重叠区域中的原始源字节。 可能有同学会问:不是有strcpy()函数(上篇博客中的介绍)用于字符串拷贝了嘛,为什么还需要memcpy()函数呢?strcpy()函数只能作用于字符串,而memcpy()函数作用于内存的内容,范围要比strcpy()函数大。我们来看例子:
#include<stdio.h>
#include<string.h>
int main()
{
int arr1[10] = { 1,2,3,4,5,6,7,8,9,10 };
int arr2[20] = { 0 };
memcpy(arr2, arr1, 40);
int i = 0;
for (i = 0; i < 20; i++)
{
printf("%d ", arr2[i]);
}
return 0;
}
我们可以看到,我们创建了两个数组arr1[]和arr2[],我们将arr1中的内容拷贝到arr2中去,但是我们要拷贝的内容是整型,因此不能用strcpy()函数来实现,只能用memcpy()函数,第三个参数size_t num,表示的是拷贝的字节数,例子中arr1中有10个整型元素,整型占4个字节,因此总共拷贝40个字节。
memmove()函数
作用:memmove()函数用于拷贝内存中的数据 形式:void *memmove( void *dest, const void *src, size_t count ); 解释:memmove函数将count字节的字符从src复制到dest。如果源区域和目标区域的某些区域重叠,memmove将确保在覆盖之前复制重叠区域中的原始源字节。 有同学会问这个函数怎么跟memcpy()函数出奇的相似呢?是的,这两个函数及其的相似,但是有不同之处。就是在拷贝重复的数据的时候。
#include<stdio.h>
#include<string.h>
int main()
{
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
memcpy(arr + 2, arr, 16);
int i = 0;
for (i = 0; i < 10; i++)
{
printf("%d ", *(arr+i));
}
return 0;
}
我们想实现将arr数组变为“1 2 1 2 3 4 7 8 9 10”;用memcpy()函数实现,将“1 2 3 4”拷贝到“3 4 5 6”中去,但是我们发现并不可以,函数memcpy()在实现作用时,将“1”拷贝给原来的“3”,将“2”拷贝给原来的“4”,当拷贝“3”时,此时的“3”已经改为了“1”,所以只能将“1”拷贝给“5”,将“2”拷贝给“6”,因此最后的打印结果为:“1 2 1 2 1 2 7 8 9 10”;但是使用memmove()函数并不会出现这种情况,memmove()函数可以实现重复拷贝,也就达到了“1 2 1 2 3 4 7 8 9 10”。因此,我们可以将函数memcpy()改为函数memmove()。
#include<stdio.h>
#include<string.h>
int main()
{
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
memmove(arr + 2, arr, 16);
int i = 0;
for (i = 0; i < 10; i++)
{
printf("%d ", *(arr+i));
}
return 0;
}
memcmp()函数
作用:memcmp()函数用于内存比较。 形式:void *memcmp( void *dest, const void *src, size_t count ); 解释:memcmp函数比较buf1和buf2的第一个计数字节,并返回一个指示它们之间关系的值。 memcmp()函数跟strcmp()函数是一样的,只是memcmp()函数可以用于其他类型,不只是字符串。 举个例子:
#include<stdio.h>
#include<string.h>
int main()
{
int arr1[] = { 1,2,3,4,5 };
int arr2[] = { 1,2,3,6,6 };
int ret = memcmp(arr1, arr2, 12);
printf("%d", ret);
return 0;
}
#include<stdio.h>
#include<string.h>
int main()
{
int arr1[] = { 1,2,3,4,5 };
int arr2[] = { 1,2,3,6,6 };
int ret = memcmp(arr1, arr2, 16);
printf("%d", ret);
return 0;
}
我们创建两个数组arr1,arr2,数组前12个字节一样,所以ret返回值为0。但当前16个字节比较时,返回值为-1。
memset()函数
作用: memset()函数用于内存设置。 形式:void *memset( void *dest, int c, size_t count ); 解释:memset函数将dest的第一个计数字节设置为字符c。 举个例子:
#include<stdio.h>
#include<string.h>
int main()
{
int arr[] = { 1,2,3,4,5,6 };
memset(arr, 0, 24);
int i = 0;
for (i = 0; i < 6; i++)
{
printf("%d ", arr[i]);
}
return 0;
}
当我们想将数组中的元素改掉时,我们可以使用memset()函数,我们将“1 2 3 4 5 6”全部改为“0”,第一个参数是要改的起始地址,例子中是数组的首元素地址,第二个参数是要设置的字符,例子中是字符“0”,第三个参数是更改的字节数,例子中是24个字节,也就是6个整型。 关于常见的内存函数就是这么多了,希望能给大家带来帮助,如果有什么建议欢迎私信,谢谢各位!
|