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


目录
相关文章
|
2天前
|
程序员 C语言 C++
【C语言基础】:动态内存管理(含经典笔试题分析)-2
【C语言基础】:动态内存管理(含经典笔试题分析)
|
2天前
|
程序员 编译器 C语言
【C语言基础】:动态内存管理(含经典笔试题分析)-1
【C语言基础】:动态内存管理(含经典笔试题分析)
|
2天前
|
存储 小程序 编译器
【C语言基础】:数据在内存中的存储
【C语言基础】:数据在内存中的存储
|
2天前
|
安全 C语言
【C语言基础】:内存操作函数
【C语言基础】:内存操作函数
|
2天前
|
C语言
【C语言基础】:字符串函数(二)
【C语言基础】:字符串函数(二)
|
2天前
|
编译器 C语言 C++
【C语言基础】:字符函数和字符串函数-2
【C语言基础】:字符函数和字符串函数
|
1天前
|
消息中间件 存储 Kafka
实时计算 Flink版产品使用问题之 从Kafka读取数据,并与两个仅在任务启动时读取一次的维度表进行内连接(inner join)时,如果没有匹配到的数据会被直接丢弃还是会被存储在内存中
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
|
3天前
|
存储 C++
C primer plus 学习笔记 第12章 存储类别、链接和内存管理
C primer plus 学习笔记 第12章 存储类别、链接和内存管理
|
11天前
|
存储 编译器 C语言
C语言学习记录——数据的存储(数据类型、类型的基本归类、整型在内存中的存储、大小端介绍、浮点型在内存中的存储)二
C语言学习记录——数据的存储(数据类型、类型的基本归类、整型在内存中的存储、大小端介绍、浮点型在内存中的存储)二
11 0
|
11天前
|
存储 编译器 C语言
C语言学习记录——数据的存储(数据类型、类型的基本归类、整型在内存中的存储、大小端介绍、浮点型在内存中的存储)一
C语言学习记录——数据的存储(数据类型、类型的基本归类、整型在内存中的存储、大小端介绍、浮点型在内存中的存储)一
19 2