C语言内存函数详解

文章目录

memcpy函数

c 复制代码
void * memcpy ( void * destination, const void * source, size_t num );

内存函数头文件是#include<string.h>

函数memcpy从source的位置开始向后复制num个字节 的数据到destination指向的内存位置。

这个函数在遇到 '\0' 的时候并不会停下来。

如果source和destination有任何的重叠,复制的结果都是未定义的。

memcpy函数拷贝结束后,会返回目标空间的起始地址

memcpy函数C语言实现:

c 复制代码
void* my_memcpy(void* dest, const void* src, int num)
{
	int i = 0;
	void* ret = dest;
	assert(dest && src);
	for (i = 0; i < num; i++)
	{
		*(char*)dest = *(char*)src;
		dest = (char*)dest+1;//这里不用后置++的原因是强制转换是临时的,当你不用的时候++已经不是这种强制类型的
		src= (char*)src+ 1;
	}
	return ret;
}
int main()
{
	int arr1[] = { 1,2,3,4,5,6,7,8,9,10 };
	int arr2[20] = { 0 };
	my_memcpy(arr2, arr1 + 2, 20);
	for(int i=0;i<20;i++)
	{
		printf("%d ",arr2[i]);
	}
	return 0;
}

memcpy函数的的使用

memcpy函数不能进行重叠内存的拷贝

memmove函数

c 复制代码
void * memmove ( void * destination, const void * source, size_t num );

memmove函数就是专门解决内存重叠拷贝时的问题。

和memcpy的差别就是memmove函数处理的源内存块和⽬标内存块是可以重叠的。

如果源空间和⽬标空间出现重叠,就得使⽤memmove函数处理。

memmove函数C语言实现

c 复制代码
void * my_memmove ( void * dst, const void * src, size_t count)
{
    void * ret = dst;
    if (dst <= src || (char *)dst >= ((char *)src + count))
    {
    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);
}
int main()
{
	int arr1[10]={1,2,3,4,5,6,7,8,9,10};
    my_memmove(arr1,arr1+2,20);
    for(int i=0;i<10;i++)
    {
		printf("%d ",arr1[i]);
	}
	return 0;
}

memmove函数使用

如果源地址和目标地址是不重叠的,memmove函数会像memcpy函数一样直接复制数据。如果源地址和目标地址重叠,memmove会采取一种高效的方法,从后向前复制数据,以避免在复制过程中覆盖数据‌

memset函数

c 复制代码
void * memset ( void * ptr, int value, size_t num );

memset是⽤来设置内存的,将内存中的值以字节为单位设置成想要的内容。

c 复制代码
#include<stdio.h>
#include<string.h>
int main()
{
	char arr[]="abcdefg";
	memset(arr,'a',5);
	printf("%s",arr);
	return 0;
} 

代码输出 aaaaafg。

c 复制代码
#include<stdio.h>
#include<string.h>
int main()
{
	int arr[]={1,2,3,4,5,6,7,8,9,10};
	memset(arr,0,40);
	for(int i=0;i<10;i++)
	{
		printf("%d ",arr[i]);
	}
	return 0;
} 

memcmp函数

⽐较从ptr1和ptr2指针指向的位置开始,向后的num个字节

c 复制代码
#include <stdio.h>
#include <string.h>
int main()
{
 char buffer1[] = "DWGAOtP12df0";
 char buffer2[] = "aWGAOTp12F0";
 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;
}

代码输出:'DWGAOtP12df0' is less than 'aWGAOTp12F0'.

比较的方式按照ASCII编码表比较。

相关推荐
zhangpeng455547940几秒前
用Java写一个MVCC例子
java·开发语言
point_zg15 分钟前
Vue报错...properly without JavaScript enabled. Please enable it to continue
开发语言·javascript·vue
普通网友23 分钟前
如何在CentOS部署青龙面板并实现无公网IP远程访问本地面板
开发语言·后端·golang
sa1002724 分钟前
基于Python的网络爬虫技术研究
开发语言·爬虫·python
API小爬虫29 分钟前
如何利用 Java 爬虫获取京东商品详情信息
java·开发语言·爬虫
Java致死34 分钟前
费马小定理
算法·费马小定理
不吃元西1 小时前
leetcode 74. 搜索二维矩阵
算法·leetcode·矩阵
杰杰批1 小时前
第十四届蓝桥杯大赛软件赛国赛C/C++研究生组
c语言·c++·蓝桥杯
小开不是小可爱1 小时前
leetcode_454. 四数相加 II_java
java·数据结构·算法·leetcode
zheshiyangyang1 小时前
JavaScript---原型和原型链
开发语言·前端·javascript