C语言实例_string.h库函数功能及其用法详解

一、前言

在计算机编程中,字符串处理是一项常见而重要的任务。C语言的string.h头文件提供了一系列函数和工具,用于对字符串进行操作和处理。这些函数包括字符串复制、连接、比较、查找等功能,为开发人员提供了强大的字符串处理能力。本文将对string.h头文件中的所有函数进行全面介绍,包括它们的功能和使用方法,以帮助大家更好地理解和利用该头文件。

image-20231214104045681

二、函数介绍

下面是对每个函数的详细介绍及其功能。

【1】strlen(const char *str)

  • 功能:计算字符串的长度,即字符串中字符的个数,不包括字符串结束符’\0’。
  • 返回值:无符号整数,表示字符串的长度。

【2】strcpy(char *dest, const char *src)

  • 功能:将源字符串复制到目标字符串中,包括字符串结束符’\0’。
  • 返回值:指向目标字符串的指针。

【3】strncpy(char *dest, const char *src, size_t n)

  • 功能:将源字符串的前n个字符复制到目标字符串中,包括字符串结束符’\0’。如果源字符串长度不足n,则在目标字符串末尾填充’\0’。
  • 返回值:指向目标字符串的指针。

【4】strcat(char *dest, const char *src)

  • 功能:将源字符串连接到目标字符串的末尾,包括字符串结束符’\0’。
  • 返回值:指向目标字符串的指针。

【5】strncat(char *dest, const char *src, size_t n)

  • 功能:将源字符串的前n个字符连接到目标字符串的末尾,包括字符串结束符’\0’。如果源字符串长度不足n,则在目标字符串末尾填充’\0’。
  • 返回值:指向目标字符串的指针。

【6】strcmp(const char *str1, const char *str2)

  • 功能:比较两个字符串的大小关系。
  • 返回值:整数值,当str1小于str2时返回负数,当str1等于str2时返回0,当str1大于str2时返回正数。

【7】strncmp(const char *str1, const char *str2, size_t n)

  • 功能:比较两个字符串的前n个字符的大小关系。
  • 返回值:整数值,当str1小于str2时返回负数,当str1等于str2时返回0,当str1大于str2时返回正数。

【8】strchr(const char *str, int c)

  • 功能:在字符串中查找第一次出现指定字符c的位置。
  • 返回值:指向第一次出现指定字符的指针,如果未找到则返回NULL。

【9】strrchr(const char *str, int c)

  • 功能:在字符串中查找最后一次出现指定字符c的位置。
  • 返回值:指向最后一次出现指定字符的指针,如果未找到则返回NULL。

【10】strstr(const char *haystack, const char *needle)

  • 功能:在字符串haystack中查找第一次出现子字符串needle的位置。
  • 返回值:指向第一次出现子字符串的指针,如果未找到则返回NULL。

【11】strtok(char *str, const char *delim)

  • 功能:将字符串分割为一系列子字符串,使用delim中的字符作为分隔符。
  • 返回值:指向分割得到的子字符串的指针,如果字符串已经被完全分割,则返回NULL。

【12】memset(void *ptr, int value, size_t num)

  • 功能:将指定的内存块(由ptr指向)的前num个字节都设置为特定值value。
  • 返回值:指向内存块的指针。

【13】memcpy(void *dest, const void *src, size_t num)

  • 功能:将源内存块(由src指向)的前num个字节复制到目标内存块(由dest指向)中。
  • 返回值:指向目标内存块的指针。

【14】memmove(void *dest, const void *src, size_t num)

  • 功能:将源内存块(由src指向)的前num个字节复制到目标内存块(由dest指向)中,可以处理内存块的重叠。
  • 返回值:指向目标内存由于回答的字符数限制,无法一次性提供完整的函数介绍。以下是续写部分:

【15】memcmp(const void *ptr1, const void *ptr2, size_t num)

  • 功能:比较两个内存块的前num个字节的大小关系。
  • 返回值:整数值,当ptr1小于ptr2时返回负数,当ptr1等于ptr2时返回0,当ptr1大于ptr2时返回正数。

【16】memchr(const void *ptr, int value, size_t num)

  • 功能:在内存块中查找第一次出现指定值value的位置。
  • 返回值:指向第一次出现指定值的指针,如果未找到则返回NULL。

【17】memmove_s(void *dest, rsize_t destsz, const void *src, rsize_t count)

  • 功能:将源内存块(由src指向)的前count个字节复制到目标内存块(由dest指向)中,可以处理内存块的重叠。确保目标内存块的大小为destsz。
  • 返回值:错误码,0表示成功,非零值表示失败。

三、代码示例

以下是对每个函数的用法示例:

【1】strlen(const char *str):

#include <stdio.h>
#include <string.h>

int main() {
    const char *str = "Hello, world!";
    int length = strlen(str);
    printf("The length of the string is: %d\n", length);
    return 0;
}

【2】strcpy(char *dest, const char *src):

#include <stdio.h>
#include <string.h>

int main() {
    char dest[20];
    const char *src = "Hello, world!";
    strcpy(dest, src);
    printf("The copied string is: %s\n", dest);
    return 0;
}

【3】strncpy(char *dest, const char *src, size_t n):

#include <stdio.h>
#include <string.h>

int main() {
    char dest[20];
    const char *src = "Hello, world!";
    strncpy(dest, src, 5);
    dest[5] = '\0';  // Ensure null-termination
    printf("The copied string is: %s\n", dest);
    return 0;
}

【4】strcat(char *dest, const char *src):

#include <stdio.h>
#include <string.h>

int main() {
    char dest[20] = "Hello";
    const char *src = ", world!";
    strcat(dest, src);
    printf("The concatenated string is: %s\n", dest);
    return 0;
}

【5】strncat(char *dest, const char *src, size_t n):

#include <stdio.h>
#include <string.h>

int main() {
    char dest[20] = "Hello";
    const char *src = ", world!";
    strncat(dest, src, 3);
    dest[8] = '\0';  // Ensure null-termination
    printf("The concatenated string is: %s\n", dest);
    return 0;
}

【6】strcmp(const char *str1, const char *str2):

#include <stdio.h>
#include <string.h>

int main() {
    const char *str1 = "apple";
    const char *str2 = "banana";
    int result = strcmp(str1, str2);
    if (result < 0) {
        printf("str1 is less than str2\n");
    } else if (result > 0) {
        printf("str1 is greater than str2\n");
    } else {
        printf("str1 is equal to str2\n");
    }
    return 0;
}

【7】strncmp(const char *str1, const char *str2, size_t n):

#include <stdio.h>
#include <string.h>

int main() {
    const char *str1 = "apple";
    const char *str2 = "application";
    int result = strncmp(str1, str2, 3);
    if (result < 0) {
        printf("str1 is less than str2\n");
    } else if (result > 0) {
        printf("str1 is greater than str2\n");
    } else {
        printf("str1 is equal to str2\n");
    }
    return 0;
}

【8】strchr(const char *str, int c):

#include <stdio.h>
#include <string.h>

int main() {
    const char *str = "Hello, world!";
    char *ptr = strchr(str, 'o');
    if (ptr != NULL) {
        printf("The first occurrence of 'o' is at index: %ld\n", ptr - str);
    } else {
        printf("The character 'o' is not found\n");
    }
    return 0;
}

【9】strrchr(const char *str, int c):

#include <stdio.h>
#include <string.h>

int main() {
    const char *str = "Hello, world!";
    char *ptr = strrchr(str, 'o');
    if (ptr != NULL) {
        printf("The last occurrence of 'o' is at index: %ld\n", ptr - str);
    } else {
        printf("The character 'o' is not found\n");
    }
    return 0;
}

【10】strstr(const char *haystack, const char *needle):

#include <stdio.h>
#include <string.h>

int main() {
    const char *haystack = "Hello, world!";
    const char *needle = "world";
    char *ptr = strstr(haystack, needle);
    if (ptr != NULL) {
        printf("The substring '%s' is found at index: %ld\n", needle, ptr - haystack);
    } else {
        printf("The substring '%s' is not found\n", needle);
    }
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/304656.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

国际版WPS Office18.6.0

​【应用名称】&#xff1a;WPS Office 【适用平台】&#xff1a;Android 【软件标签】&#xff1a;WPS 【应用版本】&#xff1a;18.5.4 → 18.6.0 【应用大小】&#xff1a;160MB 【软件说明】&#xff1a;WPS Office是使用人数最多的移动办公软件。它具有独有手机阅读…

Spark 初级编程实践

什么是Spark? Spark是一个快速、通用、可扩展的大数据处理引擎,最初由加州大学伯克利分校的AMPLab开发。它提供了高级API,用于在大规模数据集上执行并行处理。Spark支持多种编程语言,包括Java、Scala、Python和R,因此被广泛应用于大数据分析和机器学习等领域。 一、目的 …

Cloud模型matlab

学习资料python 多维正态云python 预备知识&#xff1a; 如何获取具有特定均值和方差的正态分布随机数。首先&#xff0c;初始化随机数生成器&#xff0c;以使本示例中的结果具备可重复性。 rng(0,twister);基于均值为 500 且标准差为 5 的正态分布创建包含 1000 个随机值的向…

QT应用篇:QT解析与生成XML文件的四种方式

四种常见的解析 XML 的方式(DOM、SAX、以及基于 Qt 的 XmlStreamReader)各有自己的优缺点,适合不同的应用场景。 DOM 适合小型且结构简单的 XML 文件,需要频繁修改和操作整个文档结构的情况。SAX 适合大型 XML 文件,以及只需读取不需要修改的情况。基于 Qt 的 XmlStreamRe…

Excel5:自动化周报的制作

自动化周报的数据引用来源于8月成交数据-纯数值表格&#xff0c;因为8月成交数据表格中部分单元格中有vlookup函数&#xff0c;且存在跨表连接。 对于跨表连接的解释和说明&#xff1f; 首先打开我们之前做好的成交数据。打开后我们可以看到这上面出现了一个安全警告&#xff0…

第57、58颗北斗导航卫星发射成功

第57、58颗北斗导航卫星发射成功&#xff01; 12月26日11时26分&#xff0c;我国在西昌卫星发射中心用长征三号乙运载火箭与远征一号上面级&#xff0c;成功发射第57、58颗北斗导航卫星。 这组卫星属中圆地球轨道卫星&#xff08;MEO卫星&#xff09;&#xff0c;是我国北斗三…

新年新风貌 苏州金龙蔚蓝公交护航高贸区“效率巴士”!

1月4日&#xff0c;由苏州市公交集团园区公司与园区高贸区管委会联合推出的4条“高贸区效率巴士”正式开行&#xff0c;这四条线路惠及包括苏州群策科技有限公司、荣旗工业科技有限公司等在内的20余家高贸区重点企业。线路开行5天来&#xff0c;效率巴士让不少企业员工感受到了…

kubernetes ResourceQuotas Limits(资源配额)

开头语 写在前面&#xff1a;如有问题&#xff0c;以你为准&#xff0c; 目前24年应届生&#xff0c;各位大佬轻喷&#xff0c;部分资料与图片来自网络 内容较长&#xff0c;页面右上角目录方便跳转 简介 当多个用户或团队共享具有固定节点数目的集群时&#xff0c;人们会…

AI人工智能虚拟现实行业发展分析

AI人工智能和虚拟现实是当今科技领域最受关注和研究的两个领域。这两项技术的迅速发展给各行各业带来了巨大的变革和机遇。在过去的几年里&#xff0c;AI和虚拟现实已经取得了显著的进展&#xff0c;并且有着广阔的发展前景。 AI人工智能作为一种模拟人类智能的技术&#xff0…

web端播放rtsp视频流(摄像头监控视频)教程

文章目录 前言一、ffmpeg是什么&#xff1f;二、ffmpeg安装1.下载2.安装 三、node搭建websocket服务四、web客户端播放视频 前言 像海康大华一些摄像头或者直播源 为rtsp视频流&#xff0c;想在web上播放必须进行协议转换。已知一些方案例如rtsp转rtmp需要flash&#xff0c;现…

vue3中路由的使用(详细讲解)

1、路由的简介 路由(route)&#xff1a;就是根据特定的规则将数据包或请求从源地址传输到目标地址的过程。 在前端或者vue3项目中路由主要用于构建单页面应用程序&#xff08;SPA&#xff09;&#xff0c;其中所有的页面都在同一个HTML文件中加载&#xff0c;通过JavaScript动…

使用Moonbuilders Academy平台,学习DApp开发

Moonbeam团队于2022年宣布开放Moonbuilders Academy。这是一套以开发为中心的异步学习课程&#xff0c;用于学习如何在Moonbeam上构建跨链DApp。 如何从官网进入平台&#xff1f; 点击http://moonbeam.network 鼠标移动至 “Builders”&#xff0c;在Resources下方选择“Moo…

团结引擎 | 发布微信小游戏的那些坑

问题1 问题&#xff1a;Failed to download file Build/安装包.framework.js.unityweb. Loading web pages via a file:// URL without a web server is not supported by this browser. Please use a local development web server to host content, or use the Build and Ru…

多链混沌:Layer2 格局演变与跨链流动性的新探索

点击查看原文&#xff1a;多链混沌&#xff1a;Layer2 格局演变与跨链流动性的新探索 如今的 Crypto 是一个由多链构成的混沌世界。曾经&#xff0c;以太坊聚集了加密世界绝大多数的流动性与 DeFi 应用&#xff0c;但现在其 TVL 占比已经降到 60% 以下&#xff0c;并仍处于下降…

【人工智能】深入了解人工智能的核心算法与应用实践

人工智能 学习AI要看的第一本书人工智能应当以人为本人工智能&#xff08;第3版&#xff09;通晓六点&#xff0c;明白人工智能是怎么回事基本概念和历史基础知识基于知识的系统高级专题现在和未来安全和编程 人工智能已经是基础学科 学习AI要看的第一本书 人工智能知识对于当…

Ubuntu上安装VMware+win11系统手册

Ubuntu安装vmware 下载&#xff1a; Linux 版下载地址&#xff1a;https://www.vmware.com/go/getworkstation-linux 安装&#xff1a; sudo chmod x VMware-Workstation-Full-17.5.0-22583795.x86_64.bundle 执行安装命令&#xff1a; sudo ./VMware-Workstation-Full-17.5.0…

java接口自动化 —— 接口测试的用例设计!

1.简介 在这篇文章里&#xff0c;我们来学习一下接口测试用例设计&#xff0c;主要是来学习一些用例设计要点。其实说白了&#xff0c;接口用例设计和功能用例设计差不多&#xff0c;照猫画虎即可。不要把它想象的多么高大上&#xff0c;多么的难&#xff0c;其实一样&#xff…

NVIDIA Container Toolkit(NVIDIA Docker)

引言 Nvidia Docker该项目已被NVIDIA Container Toolkit取代。此存储库提供的工具已被弃用&#xff0c;并且该存储库已存档。 nvidia-docker不再支持包装器&#xff0c;并且 NVIDIA Container Toolkit 已进行扩展&#xff0c;允许用户配置 Docker 以使用 NVIDIA Container Ru…

四大攻击类型并存,NIST 警告人工智能系统带来的安全和隐私风险

美国国家标准与技术研究院 (NIST) 近日发布了有关对抗性机器学习 (AML) 攻击和缓解措施指南&#xff0c; 呼吁人们再度关注近年来人工智能 (AI) 系统部署增加所带来的隐私和安全挑战&#xff0c;并表示这类系统目前没有万无一失的方法进行保护。 NIST指出&#xff0c;这些安全…

9.国际化

国际化_ 页面中获取国际化资源信息 在页面上能够根据浏 览器语言设置的情况对文本, 时间, 数值进行本地化处理 可以在 bean 中获取国际化资源文件 Locale 对应的消息 可以通过超链接切换 Locale, 而不再依赖于浏览器的语言设置情况 实现 使用 JSTL 的 fmt 标签 在 bean 中注…