模拟实现memcpy,memmove,memset,memcmp

memcpy

void * memcpy ( void * destination, const void * source, size_t num );

使用注意事项:

从source的位置向后复制num个字节数据到destination所指向的内存位置中。

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

\0并不会停下。

当source和destination有一定的重叠,复制的结果都是未定义的。

cpp 复制代码
void* memcpy(void* dst, const void* src, size_t count)
{
	void* ret = dst;//用一个指针指向dst
	assert(dst);
	assert(src);
	while (count--) {//将src的前count位赋值给dst
		*(char*)dst = *(char*)src;//将src的一个字节赋值给dst
		dst = (char*)dst + 1;
		src = (char*)src + 1;
	}
	return(ret);
}

memmove

memmove和memcpy函数的区别就是源内存块和目标内存块是可以重叠的。

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

memove的模拟实现

cpp 复制代码
void* 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);
}

memset

void * memset ( void * ptr, int value, size_t num );

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

cpp 复制代码
#include <stdio.h>
#include <string.h>
int main ()
{
    char str[] = "hello world";
    memset (str,'x',6);
    printf(str);
    return 0;
}

输出结果为:xxxxxxworld

memcmp

int memcmp ( const void * ptr1, const void * ptr2, size_t num );

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

相关推荐
lifallen5 分钟前
Paimon vs. HBase:全链路开销对比
java·大数据·数据结构·数据库·算法·flink·hbase
「、皓子~7 分钟前
后台管理系统的诞生 - 利用AI 1天完成整个后台管理系统的微服务后端+前端
前端·人工智能·微服务·小程序·go·ai编程·ai写作
就改了10 分钟前
Ajax——在OA系统提升性能的局部刷新
前端·javascript·ajax
凌冰_11 分钟前
Ajax 入门
前端·javascript·ajax
京东零售技术27 分钟前
京东小程序JS API仓颉改造实践
前端
老A技术联盟36 分钟前
从小白入门,基于Cursor开发一个前端小程序之Cursor 编程实践与案例分析
前端·小程序
风铃喵游39 分钟前
构建引擎: 打造小程序编译器
前端·小程序·架构
sunbyte44 分钟前
50天50个小项目 (Vue3 + Tailwindcss V4) ✨ | ThemeClock(主题时钟)
前端·javascript·css·vue.js·前端框架·tailwindcss
小飞悟1 小时前
🎯 什么是模块化?CommonJS 和 ES6 Modules 到底有什么区别?小白也能看懂
前端·javascript·设计
浏览器API调用工程师_Taylor1 小时前
AOP魔法:一招实现登录弹窗的全局拦截与动态处理
前端·javascript·vue.js