内存管理函数

简介: 内存管理函数

0️⃣memcpy

1️⃣函数声明

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

2️⃣函数功能

将source指针所指向的地址开始之后的num个字节的数据拷贝到destination所指向的地址的之后的num个字节中

3️⃣函数说明

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

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

4️⃣函数的模拟实现

void* MyMemcpy(void* dest, const void* src, size_t num)
{
  assert(dest);
  assert(src);
  void* ret = dest;
  for (int i = 0; i < num; i++)
  {
    *(char*)dest = *(char*)src;
    dest = (char*)dest + 1;
    src = (char*)src + 1;
  }
  return ret;
}

0️⃣memmove

1️⃣函数声明

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

2️⃣函数功能

将source指针所指向的地址开始之后的num个字节的数据拷贝到destination所指向的地址的之后的num个字节中(可以处理重叠的内存空间)

3️⃣函数说明

(1)如果原空间和目标空间存在重叠,如果要进行数据拷贝,则需要用memmove函数来进行

(2)为什么memmove函数可以实现重叠内存空间的数据拷贝呢?

因为memmove函数内部会对两个地址的大小进行判断进而采用不同的拷贝方式:

①destination > source的情况

memmove函数内部采用从source前面开始拷贝数据这样就不会覆盖数据了

②destinaion <  source的情况

memmove函数内部采用从source后面向前拷贝数据;

4️⃣函数实现

void* MyMemmove(void* dest, const void* src, size_t num)
{
  assert(dest);
  assert(src);
  void* ret = dest;
  if (dest < src)
  {
    while (num--)
    {
      *(char*)dest = *(char*)src;
      dest = (char*)dest + 1;
      src = (char*)src + 1;
    }
  }
  else
  {
    while (num--)
    {
      *((char*)dest + num) = *((char*)src + num);
    }
  }
  return ret;
}

0️⃣memcmp

1️⃣函数声明

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

2️⃣函数功能

比较从ptr1和ptr2指针开始的num个字节

3️⃣函数说明

返回值类型为int 和strcmp是类似的

(1)如果无差异则返回零

(2)如果遇到第一个不相同的,则返回的是ptr1所指向的内存块所存储的数据减去ptr2中的数据

4️⃣函数示例:

/* 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;
}

 

相关文章
|
26天前
|
C语言 C++
C语言 之 内存函数
C语言 之 内存函数
31 3
|
18天前
|
程序员 C++ 容器
在 C++中,realloc 函数返回 NULL 时,需要手动释放原来的内存吗?
在 C++ 中,当 realloc 函数返回 NULL 时,表示内存重新分配失败,但原内存块仍然有效,因此需要手动释放原来的内存,以避免内存泄漏。
|
1月前
|
存储 程序员 编译器
C语言——动态内存管理与内存操作函数
C语言——动态内存管理与内存操作函数
|
1月前
|
编译器 C语言 C++
详解C/C++动态内存函数(malloc、free、calloc、realloc)
详解C/C++动态内存函数(malloc、free、calloc、realloc)
124 1
|
1月前
|
程序员 C语言
C语言内存函数精讲
C语言内存函数精讲
|
13天前
|
存储 C语言
【c语言】字符串函数和内存函数
本文介绍了C语言中常用的字符串函数和内存函数,包括`strlen`、`strcpy`、`strcat`、`strcmp`、`strstr`、`strncpy`、`strncat`、`strncmp`、`strtok`、`memcpy`、`memmove`和`memset`等函数的使用方法及模拟实现。文章详细讲解了每个函数的功能、参数、返回值,并提供了具体的代码示例,帮助读者更好地理解和掌握这些函数的应用。
14 0
|
5月前
|
C语言
【C语言】:动态内存管理函数malloc,calloc,realloc和free的介绍的介绍
【C语言】:动态内存管理函数malloc,calloc,realloc和free的介绍的介绍
62 0
|
27天前
|
C语言 C++
c语言回顾-内存操作函数
c语言回顾-内存操作函数
39 0
|
29天前
|
存储 C语言 C++
来不及哀悼了,接下来上场的是C语言内存函数memcpy,memmove,memset,memcmp
本文详细介绍了C语言中的四个内存操作函数:memcpy用于无重叠复制,memmove处理重叠内存,memset用于填充特定值,memcmp用于内存区域比较。通过实例展示了它们的用法和注意事项。
61 0
|
29天前
一刻也没有为它哀悼~接下来登场的是动态内存分配的malloc与realloc以及free函数
一刻也没有为它哀悼~接下来登场的是动态内存分配的malloc与realloc以及free函数
60 0