当前位置: 首页 > 工具软件 > X-Mem > 使用案例 >

mem系列函数使用总结

赵景曜
2023-12-01

mem系列函数是我们在平时写C++的过程中经常会用到的函数,现在写一篇博客来总结一下它们的用法。mem系列函数主要是用来操作内存,使用这些函数需要在源文件中包含头文件cstring。

 

  • memset

函数原型:void *memset(void*s ,int ch,size_t n);

函数描述:将内存地址s处的n个字节的每个字节都替换为ch,并返回s。

memset函数经常用来进行数组的初始化,s即为数组的首地址,n为数组s的大小(字节数)。一般使用memset进行数值类型的数组初始化的时候,只有两种赋值方法,一种是令ch=0,另一种是令ch=-1;之所以这样赋值,是因为memset函数是按字节进行赋值的,而int、float、double等数值类型至少是四个字节或者更多,单个字节的重复赋值就导致没有办法正确地为这种多字节类型的数组进行初始化。而ch=0和ch=-1之所以可以是因为,在二进制补码中ch=0按字节表示为0000 0000,而ch=-1用二进制补码的表示为1111 1111,就4字节的int类型而言,经过多次按字节赋值后0000 0000 0000 0000 0000 0000 0000 0000仍然表示0,同样的1111 1111 1111 1111 1111 1111 1111 1111仍然表示-1。这就是为什么我们要通过memset对数值型的数组进行初始化的时候一般只使用ch=0和ch=-1的原因。当然如果是字符型数组的初始化那就另当别论了,主要原因是因为char类型的长度正好是一个字节,也就是说我们可以使用memset函数将内存s处初始化为n长度的任意字符。

 

  • memcmp

函数原型:void *memcmp(const void*buf1,const void *buf2,unsigned int count);

函数描述:比较内存区域buf1和buf2的前count个字节
当buf1<buf2时,返回值小于0
当buf1==buf2时,返回值=0
当buf1>buf2时,返回值大于0

memcmp使用的地方也非常的多,可以用它来快速比较内存中两块大小相同的区域的内容是否完全相同,比如比较两个数组中等长的一部分所有的元素是否完全相同、比较两个复杂结构体对象是否完全相同(避免了结构体中所有变量的多次比较),count的取值也就是要比较部分的字节数,一般使用sizeof来自动计算字节数。

 

  • memcpy

函数原型:void *memcpy(void* d,const void*s,size_t n)

函数描述:内存拷贝,将地址s位置的连续n个字节的内容复制到从地址d开始的内存空间上来。

可以进行快速的数组拷贝和结构体和类对象的复制,但是存在一个问题就是,如果被拷贝的源内存区域和写入的目标内存区域存在重叠的部分,那么memcpy不能保证最终拷贝结果的正确性,这个时候就需要用到memmove函数。

 

  • memmove

函数原型:void *memmove(void* dest,const void* src,size_t count);

函数描述:由src所指的内存区域复制count个字节到dest所指的内存区域。

上面也讲到了memcpy和memmove的不同,其实它们的作用都是内存信息的复制,但是在源内存区域和目标内存区域存在重叠的部分的时候,memmove是可以保证结果的正确性的。

 类似资料: