C语言内存函数和字符串函数模拟实现

简介: C语言内存函数和字符串函数模拟实现

1.模拟实现strcmp


(1)strcmp比较两个字符串,设这两个字符串为p1,p2,若p1等于p2,则返回零;若p1小于p2,则返回负数;若p1大于p2,则返回正数。

(2)模拟实现

int Mystrcmp(const char* p1, const char* p2)  //比较字符串大小
{
  while (*p1 == *p2)
  {
    if (*p1 == '\0')
      return 0;
    p1++;
    p2++;
  }
  return *p1 - *p2;
}

2.模拟实现strstr


(1)strstr(str1,str2) 函数用于判断字符串str2是否是str1的子串。如果是,则该函数返回 str1字符串从 str2第一次出现的位置开始到 str1结尾的字符串;否则,返回NULL。

(2)模拟实现

char* Mystrstr(const char* str1, const char* str2)
{
  const char* s1 = NULL;
  const char* s2 = NULL;
  char* cur = str1;
  if (*str2 == '\0')
    return (char*)str1;
  while (*cur)
  {
    s1 = cur;
    s2 = str2;
    while (*s1 != '\0' && *s2 != '\0' && *s1 == *s2)
    {
      s1++;
      s2++;
    }
    if (*s2 == '\0')
      return cur;
    cur++;
  }
  return NULL;
}

3.模拟实现strcpy


(1)strcpy()它的作用是进行字符串拷贝。strcpy()必须包含两个参数,strcpy(err2,err),将err里面的内容拷贝到err2里面去。

(2)模拟实现

char* Mystrcpy(char* err2,char*err)
{
  char* ret = err2;
  while (*err2++ = *err++)
  {
    ;
  }
  return ret;              //字符串拷贝
}

4.模拟实现strcat


(1)char * strcat ( char * err2, const char * err1 );

向err2所指向的字符串后追加err1所指向的字符串中的内容

(2)模拟实现

char* Mystrcat(char* err2, char* err1)
{
  char* re = err1;
  while (*err1 != '\0')
  {
    err1++;
  }
  while (*err1++ = *err2++)
  {
    ;
  }
  return re;              //字符串追加
}

1.内存拷贝函数memcpy()模拟实现

(1)void *memcpy( void *dest, const void *src, size_t num);


(2)函数memcpy从src的位置开始向后复制num个字节的数据到dest的内存位置。


(3)如果src和dest有任何的重叠,复制的结果都是未定义的


(4)模拟实现


void* My_memcpy(void* dest, void* src, size_t sum)
{
  assert(dest && src);
  void* cur = dest;
  while (sum--)
  {
    *(char*)dest= *(char*)src;
    ((char*)dest)++;
    ((char*)src)++;
  }
  return cur;
}
2.内存拷贝函数memmove()模拟实现

(1)和memcpy()的差别就是源内存块和目标内存块是可以重叠的

(2)模拟实现

void* My_memove(void* dest, void* src, size_t sum)
{
  assert(dest && src);
  void* cur = dest;
  if (dest<src) //前到后
  {
    while (sum--)
    {
        *(char*)dest= *(char*)src;
      ((char*)dest)++;
      ((char*)src)++;
    }
  }
  else//后到前
  {
    while (sum--)
    {
      *((char*)dest + sum) = *((char*)src + sum);
    }
  }
  return cur;
}


目录
相关文章
|
9天前
|
存储 C语言
`scanf`是C语言中用于按格式读取标准输入的函数
`scanf`是C语言中用于按格式读取标准输入的函数,通过格式字符串解析输入并存入指定变量。需注意输入格式严格匹配,并建议检查返回值以确保读取成功,提升程序健壮性。
384 0
|
3月前
|
安全 C语言 C++
比较C++的内存分配与管理方式new/delete与C语言中的malloc/realloc/calloc/free。
在实用性方面,C++的内存管理方式提供了面向对象的特性,它是处理构造和析构、需要类型安全和异常处理的首选方案。而C语言的内存管理函数适用于简单的内存分配,例如分配原始内存块或复杂性较低的数据结构,没有构造和析构的要求。当从C迁移到C++,或在C++中使用C代码时,了解两种内存管理方式的差异非常重要。
127 26
|
3月前
|
安全 C语言
C语言中的字符、字符串及内存操作函数详细讲解
通过这些函数的正确使用,可以有效管理字符串和内存操作,它们是C语言编程中不可或缺的工具。
242 15
|
8月前
|
人工智能 Java 程序员
一文彻底搞清楚C语言的函数
本文介绍C语言函数:函数是程序模块化的工具,由函数头和函数体组成,涵盖定义、调用、参数传递及声明等内容。值传递确保实参不受影响,函数声明增强代码可读性。君志所向,一往无前!
195 1
一文彻底搞清楚C语言的函数
|
9月前
|
存储 编译器 C语言
【C语言程序设计——函数】分数数列求和2(头歌实践教学平台习题)【合集】
函数首部:按照 C 语言语法,函数的定义首部表明这是一个自定义函数,函数名为fun,它接收一个整型参数n,用于指定要求阶乘的那个数,并且函数的返回值类型为float(在实际中如果阶乘结果数值较大,用float可能会有精度损失,也可以考虑使用double等更合适的数据类型,这里以float为例)。例如:// 函数体代码将放在这里函数体内部变量定义:在函数体中,首先需要定义一些变量来辅助完成阶乘的计算。比如需要定义一个变量(通常为float或double类型,这里假设用float。
201 3
|
3月前
|
存储
阿里云轻量应用服务器收费标准价格表:200Mbps带宽、CPU内存及存储配置详解
阿里云香港轻量应用服务器,200Mbps带宽,免备案,支持多IP及国际线路,月租25元起,年付享8.5折优惠,适用于网站、应用等多种场景。
796 0
|
3月前
|
存储 缓存 NoSQL
内存管理基础:数据结构的存储方式
数据结构在内存中的存储方式主要包括连续存储、链式存储、索引存储和散列存储。连续存储如数组,数据元素按顺序连续存放,访问速度快但扩展性差;链式存储如链表,通过指针连接分散的节点,便于插入删除但访问效率低;索引存储通过索引表提高查找效率,常用于数据库系统;散列存储如哈希表,通过哈希函数实现快速存取,但需处理冲突。不同场景下应根据访问模式、数据规模和操作频率选择合适的存储结构,甚至结合多种方式以达到最优性能。掌握这些存储机制是构建高效程序和理解高级数据结构的基础。
223 1
|
3月前
|
存储 弹性计算 固态存储
阿里云服务器配置费用整理,支持一万人CPU内存、公网带宽和存储IO性能全解析
要支撑1万人在线流量,需选择阿里云企业级ECS服务器,如通用型g系列、高主频型hf系列或通用算力型u1实例,配置如16核64G及以上,搭配高带宽与SSD/ESSD云盘,费用约数千元每月。
221 0

热门文章

最新文章