C语言进阶学习日志 字符串与内存函数(二)

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: C语言进阶学习日志 字符串与内存函数(二)

对内存进行操作的函数:

memcpy函数:

和strcpy一样的 也是拷贝 只不过是对内存进行操作

d01474e7425f4649a1f692c41e94371b.png

前面的参数与strcpy是一样的 只不过最后那个参数是要拷贝的字节数

#include <stdio.h>
int main()
{
   char arr[]={1,2,3,4,5,6,7,8,9};
   char arr1[6]={0};
   memcpy(arr1,arr,5*sizeof(arr[0]));
   arr1的结果1,2,3,4,5,0
}
#include <stdio.h>
#include <assert.h>
void* my_memcpy(void* rest,const void* tmp,int num)
{
  assert(rest && tmp);
  void* ret = rest;
  while (num--)
  {
    *(char*)rest = *(char*)tmp;
    (char*)rest += 1;
    (char*)tmp += 1;
  }
  return ret;
}
int main()
{
  char arr[] = "sddfg";
  char arr1[] = "xxxxxxxxxxx";
  //memcpy(arr, arr1,2);
  my_memcpy(arr1, arr,7);
  printf("%s", arr1);
}

对于内存重叠 最好使用memmove

c语言只要求:

memcpy能拷贝不重叠的内存空间就可以了

memmove去处理那些重叠内存拷贝

但 vs发现memcpy也能实现重叠拷贝

具体内存重叠是什么情况内
#include <stdio.h>
int main()
{
  int arr[]={1,2,3,4,5,6,7,8,9};
  像上面模拟实现memcpy的写法 在内存重叠时是这样的
  my_memcpy(arr+2,arr,5*sizeof(arr[0]));
}

你想把 1,2,3,4,5 放到2后面 理想的结果是1,2,1,2,3,4,5,8,9

但是实际上呢 是这样的1,2,1,2,1,2,1,8,9

因为当我们在放第三个的时候 那个地方的3已经被之前的赋值改成了1了 用已经改变了的值赋值肯定是不可以的

所以memmove就出现了

memmove函数:

84aeeca86499467c809e2e65784e0a59.png

这是一个我们实现memmove函数的思路

30fd575c5a85453cb783dfd71ab2d9f6.png

注意 我们的memmove函数的第一个参数是被考入的空间 第二个是考入的地址空间 第三个是 考入数据的字节数

#include <stdio.h>
#include <assert.h>
void* my_memmove(void* pc,const void* pc1,int num)
{
  assert(pc&&pc1);
  void* ret = pc;
  if (pc < pc1)//由前往后
  {
    int k = 0;
    while (k < num)
    {
      *((char*)pc + k) = *((char*)pc1 + k);
      k++;
    }
  }
  else//由后往前
  {
    while (num--)
    {
      *((char*)pc + num) = *((char*)pc1 + num);
    }
  }
  return ret;
}
int main()
{
  char ch[] = "abcdefgh";
  printf("%s",(char*)my_memmove(ch, ch+2, 4));
}

因为是对内存进行操作 我们也不知道传进来的会是什么类型 所以这个函数的参数是 void 类型的 所以我们在操作的时候 把他们用一个一个字节来拷贝

memcmp函数:

同样这个是对内存进行比较的函数6f56bf9740f042b58a5cdf1793f136ed.png

memset函数:

这个是对内存进行一个赋值的函数


859734cace914a2d81075cd99184510f.png

#include <stdio.h>
int main()
{
   char arr[3][3];
   memset(arr,' ',sizeof(arr));
   这样整个数组都是 ' '
}

这样 对内存操作的函数就说完了 祝大家都能收到自己心仪大厂的offer

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
10天前
|
存储 C语言
C语言如何使用结构体和指针来操作动态分配的内存
在C语言中,通过定义结构体并使用指向该结构体的指针,可以对动态分配的内存进行操作。首先利用 `malloc` 或 `calloc` 分配内存,然后通过指针访问和修改结构体成员,最后用 `free` 释放内存,实现资源的有效管理。
55 12
|
2天前
|
并行计算 算法 测试技术
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面
C语言因高效灵活被广泛应用于软件开发。本文探讨了优化C语言程序性能的策略,涵盖算法优化、代码结构优化、内存管理优化、编译器优化、数据结构优化、并行计算优化及性能测试与分析七个方面,旨在通过综合策略提升程序性能,满足实际需求。
12 1
|
7天前
|
存储 C语言 计算机视觉
在C语言中指针数组和数组指针在动态内存分配中的应用
在C语言中,指针数组和数组指针均可用于动态内存分配。指针数组是数组的每个元素都是指针,可用于指向多个动态分配的内存块;数组指针则指向一个数组,可动态分配和管理大型数据结构。两者结合使用,灵活高效地管理内存。
|
2月前
|
程序员 C++ 容器
在 C++中,realloc 函数返回 NULL 时,需要手动释放原来的内存吗?
在 C++ 中,当 realloc 函数返回 NULL 时,表示内存重新分配失败,但原内存块仍然有效,因此需要手动释放原来的内存,以避免内存泄漏。
|
2月前
|
Arthas 监控 Java
JVM知识体系学习七:了解JVM常用命令行参数、GC日志详解、调优三大方面(JVM规划和预调优、优化JVM环境、JVM运行出现的各种问题)、Arthas
这篇文章全面介绍了JVM的命令行参数、GC日志分析以及性能调优的各个方面,包括监控工具使用和实际案例分析。
51 3
|
2月前
|
存储 C语言
【c语言】字符串函数和内存函数
本文介绍了C语言中常用的字符串函数和内存函数,包括`strlen`、`strcpy`、`strcat`、`strcmp`、`strstr`、`strncpy`、`strncat`、`strncmp`、`strtok`、`memcpy`、`memmove`和`memset`等函数的使用方法及模拟实现。文章详细讲解了每个函数的功能、参数、返回值,并提供了具体的代码示例,帮助读者更好地理解和掌握这些函数的应用。
26 0
|
2月前
|
Python
log日志学习
【10月更文挑战第9天】 python处理log打印模块log的使用和介绍
35 0
|
4月前
|
存储 编译器 C语言
【C语言篇】数据在内存中的存储(超详细)
浮点数就采⽤下⾯的规则表⽰,即指数E的真实值加上127(或1023),再将有效数字M去掉整数部分的1。
389 0
|
2月前
|
存储 C语言
数据在内存中的存储方式
本文介绍了计算机中整数和浮点数的存储方式,包括整数的原码、反码、补码,以及浮点数的IEEE754标准存储格式。同时,探讨了大小端字节序的概念及其判断方法,通过实例代码展示了这些概念的实际应用。
64 1
|
2月前
|
存储
共用体在内存中如何存储数据
共用体(Union)在内存中为所有成员分配同一段内存空间,大小等于最大成员所需的空间。这意味着所有成员共享同一块内存,但同一时间只能存储其中一个成员的数据,无法同时保存多个成员的值。