字符函数和字符串函数(上)

简介: 字符函数和字符串函数

前言

C语言中对字符和字符串的处理很是频繁,但是C语言本身是没有字符串类型的,字符串通常放在常量字符串中或者字符数组中。字符串常量适用于那些对它不做修改的字符串函数

一、字符串函数

1.strlen

函数介绍:

size_t strlen ( const char * str );

函数功能:

求字符串的长度

  • 字符串已经 '\0' 作为结束标志,strlen函数返回的是在字符串中 '\0' 前面出现的字符个数(不包
  • 含 '\0' )。
  • 参数指向的字符串必须要以 '\0' 结束。
  • 注意函数的返回值为size_t,是无符号的( 易错 )
  • 学会strlen函数的模拟实现

strlen模拟实现

#include<stdio.h>
#include<string.h>
#include<assert.h>
size_t my_strlen(const char* p)
{
  int count = 0;
  assert(p != NULL);//如果等于空指针就会报错
  while((*p) != '\0')
  {
    count++;
    p++;
  }
  return count;
}
int main()
{
  char arr[] = "CSDN";
  int ret = my_strlen(arr);
  printf("%d", ret);
  return 0;
}

2.strcpy

函数介绍:

char * strcpy ( char * destination, const char * source );

函数功能:

字符串拷贝函数,把源字符串拷贝到目标空间

注意事项:

  • 源字符串必须以 '\0' 结束。
  • 会将源字符串中的 '\0' 拷贝到目标空间。
  • 目标空间必须足够大,以确保能存放源字符串。
  • 目标空间必须可变。

strcpy模拟实现

char* my_strcpy(char* dest, const char* src)
{
  assert(dest && src);
  char* ret = dest;
  while (*dest++ = *src++)
  {
    ;
  }
  return ret;
}
int main()
{
  char arr1[20] = { 0 };
  char arr2[] = "hello world";
  my_strcpy(arr1, arr2);
  printf("%s\n", arr1);
  return 0;
}

3.strcat

函数介绍:

char * strcat ( char * destination, const char * source );

函数功能:

字符串追加函数,将源字符串追加到目标字符串后面,目标中的终止字符’\0’会被源字符串的第一个字符覆盖

注意事项:

  • 源字符串必须以 '\0' 结束。
  • 目标空间必须有足够的大,能容纳下源字符串的内容。
  • 目标空间必须可修改。
  • 字符串自己给自己追加,如何?

strcat模拟实现

char* my_strcat(char* dest, const char* src)
{
  assert(dest && src);
  char* ret = dest;
  //找目标空间的'\0'
  while (*dest != '\0')
  {
    dest++;
  }
  //追加
  while (*dest++ = *src++)
  {
    ;
  }
  return ret;
}
int main()
{
  char arr1[20] = "hello ";
  char arr2[] = "world";
  my_strcat(arr1, arr2);
  printf("%s\n", arr1);
  return 0;
}

4.strcmp

函数介绍:

int strcmp ( const char * str1, const char * str2 );

函数功能:

字符串比较函数

注意事项:

  • 这里比较的不是两个字符串的长度,而是对应位置上的ASCII值
  • 第一个字符串大于第二个字符串,则返回大于0的数字
  • 第一个字符串等于第二个字符串,则返回0
  • 第一个字符串小于第二个字符串,则返回小于0的数字

strcmp模拟实现

int my_strcmp(const char* str1, const char* str2)
{
  assert(str1 && str2);
  while (*str1 == *str2)//如果相等就进去,两个指针加加,但是可能会出现两个字符串相等的情况,两个指针都指向'\0',此时比较就结束了
  {
    if (*str1 == '\0')
    {
      return 0;
    }
    str1++;
    str2++;
  }
  if (*str1 > *str2)
  {
    return 1;
  }
  else
  {
    return -1;
  }
}
int main()
{
  char arr1[] = "abq";
  char arr2[] = "abq";
  int ret=my_strcmp(arr1, arr2);
  printf("%d\n", ret);
  return 0;
}

5.strncpy

函数介绍:

char * strncpy ( char * destination, const char * source, size_t num );

函数功能:

长度受限的字符串拷贝函数

注意事项:

  • 拷贝num个字符从源字符串到目标空间。
  • 如果源字符串的长度小于num,则拷贝完源字符串之后,在目标的后边追加0,直到num个。

strncpy模拟实现

char* my_strncpy(char* dest, const char* src, int num)
{
  assert(dest && src);
  char* ret = dest;
  while (num)
  {
    if (*src == '\0')//此时说明src指针已经指向了待拷贝字符串的结束标志'\0'处,src指针就不用再++了
    {
      *dest = '\0';
      dest++;
    }
    else
    {
      *dest = *src;
      dest++;
      src++;
    }
    num--;
  }
  return ret;
}
int main()
{
  char arr1[20] = "xxxxxxxxxxxxxxxxxxx";
  my_strncpy(arr1, "abcdef", 10);
  printf("%s\n", arr1);
  return 0;
}

6.strncat

函数介绍:

char * strncat ( char * destination, const char * source, size_t num );

函数功能:

长度受限的字符串追加函数

注意事项:

  • 从源字符串的第一个字符开始往后数num个字符追加到目标空间的后面,外加一个终止字符。
  • 如果源字符串的长度小于 num,则仅复制终止字符之前的内容。.

strncat模拟实现

char* my_strncat(char* dest, const char* src, int sz)
{
  assert(dest && src);
  char* ret = dest;
  //找目标空间的\0
  while (*dest != '\0')
  {
    dest++;
  }
  //追加
  while (sz)
  {
    *dest++ = *src++;
    sz--;
  }
  *dest = '\0';
  return ret;
}
int main()
{
  char arr1[20] = "abc\0xxxxxxxxxxx";
  my_strncat(arr1, "defjhigk", 3);
  printf("%s\n", arr1);
  return 0;
}

7.strncmp

函数介绍:

int strncmp ( const char * str1, const char * str2, size_t num );

函数功能:

长度受限的字符串比较函数

注意事项:

  • 比较到出现另个字符不一样或者一个字符串结束或者num个字符全部比较完。

strncmp模拟实现

int my_strncmp(const char* str1, const char* str2, int sz)
{
  assert(str1 && str2);
  while (sz)
  {
    if (*str1 < *str2)
    {
      return -1;
    }
    else if (*str1 > *str2)
    {
      return 1;
    }
    else if(*str1 == '\0'||*str2 =='\0')//当有一个为'\0',说明比较就可以结束了

字符函数和字符串函数(下)+https://developer.aliyun.com/article/1384935

相关文章
|
存储 SQL 关系型数据库
【MySQL 数据库】9、存储过程
【MySQL 数据库】9、存储过程
1126 0
|
安全 编译器 Swift
Swift开发
Swift开发
349 9
|
机器学习/深度学习 人工智能 算法
深度学习在图像识别中的应用与挑战
本文深入探讨了深度学习技术在图像识别领域的广泛应用及其面临的主要挑战。首先,文章概述了深度学习技术的基本原理和关键算法,随后详细分析了深度学习在图像识别中的成功案例,包括面部识别、自动驾驶车辆的视觉系统以及医学图像分析等。此外,本文还讨论了深度学习在实际应用中遇到的挑战,如数据偏见、模型泛化能力和计算资源的需求等问题。最后,文章展望了未来深度学习技术的发展方向,特别是在提高模型透明度和解释能力方面的可能进展。
139 26
|
存储 算法
力扣每日一题 6/20 数学+数组
力扣每日一题 6/20 数学+数组
114 1
|
机器学习/深度学习 边缘计算 人工智能
拥抱变革:我的云计算技术感悟之旅
【4月更文挑战第2天】 在信息技术不断演进的今天,云计算已成为推动企业数字化转型的重要力量。本文以个人视角切入,分享了我在学习和实践云计算过程中的技术感悟。文章不仅总结了云计算的核心优势和面临的挑战,还探讨了如何通过持续学习和实践来提升云技术水平,以及对未来云计算技术趋势的展望。
87 1
|
编译器 Go
【LeetCode】剑指 Offer <二刷>(5)
【LeetCode】剑指 Offer <二刷>(5)
162 0
|
编译器 C语言 C++
模拟实现strcmp
模拟实现strcmp
|
搜索推荐 SEO
分享5个SEO做优化技巧
分享5个SEO做优化技巧:https://www.20200824.com/search.php?q=SEO
206 0
|
缓存 Kubernetes Cloud Native
带你读《云原生应用开发 Operator原理与实践》第二章 Operator 原理2.2Client-go 原理(十七)
带你读《云原生应用开发 Operator原理与实践》第二章 Operator 原理2.2Client-go 原理
|
Kubernetes jenkins 持续交付
CICD从Gitlab到Coderun
背景 我们是一个10人小团队,因为本人之前接触过Docker和Drone,所有项目开发阶段开始的时候就确定使用CICD和Docker的方式进行开发与部署。前期为了方便我们直接使用Gitlab.com(不是私有部署)进行代码仓库的存储于Gitlab CI进行构建,然后通过Gitlab Runner部署到阿里云的开发服务器上。
4912 0