Linux C语言:字符串处理函数

news2025/1/16 21:16:44

一、字符串函数

1、C库中实现了很多字符串处理函数

#include <string.h>
  • ① 求字符串长度的函数strlen
  • ② 字符串拷贝函数strcpy
  • ③ 字符串连接函数strcat
  • ④ 字符串比较函数strcmp

 2、字符串长度函数strlen

  • 格式:strlen(字符数组)
  • 功能:计算字符串长度
  • 返值:返回字符串实际长度,不包括‘\0’在内

        – 例:对于以下字符串,strlen(s)的值为:

char s[10]={‘A’,‘\0’,‘B’,‘C’,‘\0’,‘D’};
char s[ ]=“\t\v\\\0will\n”;
char s[ ]=“\x69\141\n”; //\xhh表示十六进制数代表的符号 \ddd表示8进制的
答案:1 3 3

3、字符串拷贝函数strcpy

  • 格式:strcpy(字符数组1,字符串2)
  • 功能:将字符串2,拷贝到字符数组1中去
  • 返值:返回字符数组1的首地址

说明:

  1. 字符数组1必须足够大
  2. 拷贝时‘\0’一同拷贝

4、字符串连接函数strcat

  • 格式:strcat(字符数组1,字符数组2)
  • 功能:把字符数组2连到字符数组1后面
  • 返值:返回字符数组1的首地址

说明:

  1. 字符数组1必须足够大
  2. 连接前,两串均以‘\0’结束;连接后,串1的 ‘\0’取消,新串最后加‘\0’ 
#include <string.h>
#include <stdio.h>
int main()
{
    char destination[25];
    char blank[] = " ", c[]= "C++",
    turbo[] = "Turbo";
    strcpy(destination, turbo);
    strcat(destination, blank);
    strcat(destination, c);
    printf("%s\n", destination);
return 0;
}

5、字符串比较函数strcmp

  • 格 式:strcmp(字符串1,字符串2)
  • 功 能:比较两个字符串
  • 比较规则:对两串从左向右逐个字符比较(ASCII码),直到遇到不同字符或‘\0’为止
  • 返 值:返回int型整数
  1. a. 若字符串1< 字符串2, 返回负整数
  2. b. 若字符串1> 字符串2, 返回正整数
  3. c. 若字符串1== 字符串2, 返回零

6、isalpha函数

  • 包含头文件
#include <ctype.h>
  • 函数声明
int isalpha(int c);
  • 功能说明
  • 判断参数c是否为字母
  • 返回值
  • 0-不是字母 非0-是字母 
    #include <stdio.h>
    int main()
    {
    printf("isalpha('0')=%d\n",isalpha('0'));
    printf("isalpha('a')=%d\n",isalpha('a'));
    printf("isalpha('A')=%d\n",isalpha('A'));
    }

7、 isupper() 函数

  • 包含头文件
#include <ctype.h>
  • 函数声明
int isupper(int c);
  • 功能说明
  • 判断参数c是否为大写字母
  • 返回值
  • 0-不是大写字母 非0-是大写字母
    #include <stdio.h>
    int main()
    {
    printf("isupper('-')=%d\n",isupper('-'));
    printf("isupper('0')=%d\n",isupper('0'));
    printf("isupper('a')=%d\n",isupper('a'));
    printf("isupper('A')=%d\n",isupper('A'));
    }

 7、toupper() 函数

  • 包含头文件
#include <ctype.h>
  • 函数声明
int toupper(int c);
  • 功能说明
  • 把小写字母转换为大写字母,如果参数c不是小写字母就不转换
  • 返回值
  • 返回值为转换后的结果。

8、tolower() 函数

  • 包含头文件
#include <ctype.h>
  • 函数声明
int toupper(int c);
  • 功能说明

        将给定的大写字母转换为对应的小写字母。如果给定的字符不是大写字母,则不对它做任何处理,也不会报错或者警告。

  • 返回值

        如果传入的字符是大写字母,则返回该字母的小写形式;如果传入的字符不是大写字母,则原样返回该字符。 

二、 strncpy函数

1、strncpy()函数用法

char * strncpy ( char * dest, const char * src, size_t n )
  • dest:目标字符串,即要将源字符串复制到的位置。
  • src:源字符串,即要复制的字符串。
  • n:要复制的字符数。

        目标字符串dest必须足够大,以容纳要复制的以及额外的'\0'。否则,可能会导致缓冲区溢出的问题。 

2、strncpy函数注意事项 

  1) 如果源字符串的长度大于或等于n,则目标字符串将不会以'\0'结尾,需要手动添加'\0'。 

#include <stdio.h>
#include <string.h>
int main() {
char dest[20];
char src[] = "helllo world!";
strncpy(dest, src, 8);
dest[8] = '\0';
printf("%s\n", dest);
return 0;
}

        使用strncpy函数将src的前8个字符复制到dest中。由于源字符串的长度大于或等于n,我们需要在dest的后面添加'\0'。

 

2) 如果源字符串的长度小于n,则复制完源字符串后,会用'\0'填充剩余的空间。

char *strncpy(char *dest, const char *src, int len) {
assert(dest != NULL && src != NULL);
char *res = dest;
int offset = 0;
if (strlen(src) < len) { //src长度小于len
offset = len - strlen(src);
len = strlen(src);
}
while (len--) {
*dest++ = *src++;
}
while (offset--) {
*dest++ = '\0';
}
return res;
}

 

三、strncat函数 

1、函数原型:

char* strncat(char* dest, const char* src, int n)

2、头 文 件:

#include <string.h>

3、返 回 值:

        返回dest字符串的起始地址

4、说 明:

  • 1. dest要有足够的空间来容纳要拷贝的字符串
  • 2. strncat会将dest字符串最后的’\0’覆盖掉,字符追加完成后,再追加’\0’
  • 3. 如果源字符串的长度小于n,会将源字符串的全部字符追加到目标字符串中。如果源字符串的长度大于或等于n,则只会将源字符串的前n个字符追加到目标字符串中。

5、用法示例 

#include <stdio.h>
#include <string.h>
int main()
{
    char dest[20] = { "hello " };
    char src[] = { "world!" };
    strncat(dest, src, 5);
    printf("%s\n", dest);
return 0;
}

6、函数实现 

#include <stdio.h>
#include<string.h>
#include <assert.h>
//dest为前面的字符串,src为后面要加的字符串,n为要拷贝的字符个数
char* My_strncat(char* dest, const char* src, int n) {
char* ret = dest; //将dest首地址储存在ret中
assert(dest != NULL && src != NULL); //保证dest、src非空
while (*dest != '\0')//用指针往后一个个找,找到dest结尾的‘\0’
dest++;
while (n && (*dest++ = *src++) != '\0')//把src里的字符一个个放入dest后
//(*dest++ = *src++) 表示先把*src赋给*dest,再把两个指针同时往后移
n--; //循环跳出条件
*dest = '\0'; //字符追加完成后,再追加’\0’
return ret; //返回dest字符串起始地址
}

int main() {
    char arr1[20] = "I LOVE YOU ";
    My_strncat(arr1, "SORRY" ,3);
//经过函数My_strncat后 ,arr1里应该是字符串I LOVE YOU
    SOR
    printf("arr1: %s\n", arr1);
return 0;
}

四、strncmp函数

1、函数原型: 

int strncmp(const char* str1, const char* str2, size_t n)

2、头 文 件:

#include <string.h>

3、返回值:

str1 = str2 则返回0,
str1 > str2 则返回大于0的值,
str1 < str2 则返回小于0的值
  • 将str1字符串的第一个字符的ACSII值减去str2第一个字符的ACSII值(自左向右比较前n个字符,直到出现不同的字符或遇'\0'为止)
  •  若差值为零则继续比较下去;若差值不为零,则返回差值。

4、 strncmp函数实现

//以’\0’结尾的字符串 const修饰防止字符串被修改,进行保护
int My_strncmp(const char* str1, const char* str2, int n) {
if (!n) //n=0时,无字符要比,直接return 0
return 0;
while (--n && *str1 && *str1 == *str2) {
//当字符相等且不为’\0’时比较下个字符,直到n=0比完
str1++;
str2++;
}
return *str1 - *str2;
//字符不相等时,(*str1 - *str2)可以满足返回值正负的需求
}

 5、用法示例:

int main() {
    char str1[] = "SSLOVE YOU ";
    char str2[] = "SORRY";
//经过手算可发现O的ACSII=79,S的ACSII=83,应该返回4
    printf("%d\n", My_strncmp(str1, str2,2));
return 0;
}

 6、strchr函数

1、函数原型: 

char *strchr(const char *str, int c);

2、参数说明:

str:要搜索的字符串。
c:要查找的字符,作为一个整数传递给函数。

3、返回值:

  • 如果找到了字符 c,则返回一个指向该字符的指针。
  • 如果未找到字符 c,则返回 NULL 指针。

4、功能:

  • 用于查找字符在字符串中第一次出现的位置
#include <stdio.h>
char *myStrchr(char *str, int c) {
    while (*str != '\0') {
    if (*str == c) {
    return str;
}
    str++;
}
return NULL;
}
int main() {
    char *str = "Hello, world!";
    char *result = myStrchr(str, 'o');
    if (result != NULL) {
    printf("在字符串中找到字符 'o',位置为:%ld\n", result - str);
} else {
    printf("未找到字符 'o'。\n");
}
return 0;
}
int main()
{
char str1[] = { "eeeabcaaa" };
char str2[] = { "abc" };
char* ret = my_strstr(str1, str2);
    if (*ret != NULL)
    printf("%s", ret);
else
    printf("没找到!");
return 0;
}

7、 strstr函数

1、函数原型: 

char * strstr ( const char * str1, const char * str2 );

2、功能:

  • 返回字符串中首次出现子串的地址

3、参数:

1.str1:要扫描的 C 字符串
2.str2:包含要匹配的字符序列的 C 字符串。

4、返回值:

  • 返回指向 str2 中第一次出现的 str1 的指针,如果 str2 不是 str1的一部分,则返回一个空指针。匹配过程不包括终止’\0’,但它到此为止。

5、strstr函数的模拟

int main()
{
char str1[] = { "eeeabcaaa" };
char str2[] = { "abc" };
char* ret = my_strstr(str1, str2);
    if (*ret != NULL)
    printf("%s", ret);
else
    printf("没找到!");
return 0;
}

#include <stdio.h>
char* my_strstr(const char* str1, const char* str2) {
char* p = str1;//保存每次比较的起始地址
char* s1 = p;//初始指针s1
char* s2 = str2;//初始指针s2
while (*p != '\0') {//挨个遍历主字符串
    s1 = p;//赋值s1每次比较初地址
    s2 = str2;//赋值子 字符串的首地址
while (*s1!='\0' && *s2 != '\0' &&*s1 == *s2) { //比较字串与主串
    s1++;
    s2++;
}
    if (*s2 == '\0')//当字串比较到字串的\0 时,说明已经比较完字串,找到了
return p;//返回保存的初始比较位置
    p++;//挨个遍历主字符串
}
return NULL;
}

int main()
{
char str1[] = { "eeeabcaaa" };
char str2[] = { "abc" };
char* ret = my_strstr(str1, str2);
    if (*ret != NULL)
    printf("%s", ret);
else
    printf("没找到!");
return 0;
}

6、strstr函数的使用

#include <stdio.h>
#include <string.h>
int main() {
char str1[] = { "eeeabcaaa" };
char str2[] = { "abc" };
char* ret = strstr(str1, str2);
    if (*ret != NULL)
    printf("%s", ret);
else
    printf("没找到!");
return 0;
}

 

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

LLM中表格处理与多模态表格理解

文档处理中不可避免的遇到表格&#xff0c;关于表格的处理问题&#xff0c;整理如下&#xff0c;供各位参考。 问题描述 RAG中&#xff0c;对上传文档完成版式处理后进行切片&#xff0c;切片前如果识别文档元素是表格&#xff0c;那么则需要对表格进行处理。一般而言&#x…

【UML用户指南】-17-对基本行为建模-交互

目录 1、消息的可视化表示 2、对象与角色 3、链和连接件 4、消息 5、序列 6、创建、修改和撤销 7、表示法 8、常用建模技术 8.1、对控制流建模 8.1.1、基于时间的控制流 8.1.2、基于结构的控制流 在任何有意义的系统中&#xff0c;对象都不是孤立存在的&#xff0c;…

SQL优化选对执行计划,查询速度提升1000倍 | OceanBase 应用实践

作者&#xff1a;爱可生数据库高级工程师任仲禹&#xff0c;擅长故障分析和性能优化。 本文通过一个案例&#xff0c;分享使用OceanBase时&#xff0c;SQL走错执行计划&#xff0c;而导致慢SQL的排查方法论。 案例背景 在使用OceanBase 3.2.3 版本的过程中&#xff0c;项目组反…

Spring的SmartLifecycle可以没用过,但没听过就不好了! - 第517篇

历史文章&#xff08;文章累计500&#xff09; 《国内最全的Spring Boot系列之一》 《国内最全的Spring Boot系列之二》 《国内最全的Spring Boot系列之三》 《国内最全的Spring Boot系列之四》 《国内最全的Spring Boot系列之五》 《国内最全的Spring Boot系列之六》 《…

HTML基础结构入门

HTML&#xff08;超文本标记语言&#xff09;是构建网页的基础语言。它用于描述网页的结构和内容。让我们从最基本的HTML文档开始。 HTML基础结构 一个基本的HTML文档结构如下&#xff1a; <!DOCTYPE html> <html lang"zh-CN"> <head><meta …

PMP证书有何用?

PMP证书有何用&#xff1f; PMP项目管理专业人士资格认证证书对从事或希望从事项目管理工作的人员有重要意义&#xff0c;具体体现在以下几个方面&#xff1a; 1. 提供职业机会&#xff1a; PMP是项目管理领域的国际认可标准&#xff0c;拥有该证书的人在求职时具备了更强的…

python-docx-template 的 Replace docx pictures 占位图片名称从哪来?

python-docx-template 的 Replace docx pictures 占位图片名称从哪来&#xff1f; 在 Word 中看占位图片名称用代码输出输出结果找对应图片 使用 replace_pic参考资料 在 Word 中看占位图片名称 右键图片 》查看可选文字 用代码输出 from docxtpl import DocxTemplate# 初始化…

【proteus仿真】基于51单片机的电压检测系统

【proteus仿真】基于51单片机的电压检测系统 资料下载地址&#xff1a;关注公众号 小邵爱电子 获取 1.前言 使用51单片机和ADC模块设计一个数字电压表&#xff0c;将模拟信号0~5V之间的电压转换为数字量信号&#xff0c;并通过LED实时显示电压数据 、 2.仿真原理图 3.硬件…

python安装目录文件说明----Dlls文件夹

在Python的安装目录下&#xff0c;通常会有一个DLLs文件夹&#xff0c;它是Python标准库的一部分。这个文件夹包含了一些动态链接库&#xff08;Dynamic Link Libraries&#xff0c;DLL&#xff09;&#xff0c;这些库提供了Python解释器和标准库的一些关键功能。以下是对这个文…

Linux(Centos7)OpenSSH漏洞修复,升级最新openssh-9.7p1

OpenSSH更新 一、OpenSSH漏洞二、安装zlib三、安装OpenSSL四、安装OpenSSH 一、OpenSSH漏洞 服务器被扫描出了漏洞需要修复&#xff0c;准备升级为最新openssh服务 1. 使用ssh -v查看本机ssh服务版本号 ssh -V虚拟机为OpenSSH7.4p1&#xff0c;现在准备升级为OpenSSH9.7p1…

Windows 与 Java 环境下的 Redis 利用分析

1 前言 在最近的一次攻防演练中&#xff0c;遇到了两个未授权访问的 Redis 实例。起初以为可以直接利用&#xff0c;但后来发现竟然是Windows Java (Tomcat)。因为网上没有看到相关的利用文章&#xff0c;所以在经过摸索&#xff0c;成功解决之后决定简单写一写。 本文介绍了…

洗地机性价比高的是哪一款?行内人告诉你

在浏览前&#xff0c;希望您轻触屏幕上方的“关注”按钮&#xff0c;让我后续为您带来更多实用且精彩的内容&#xff0c;感谢您的支持&#xff01; 洗地机作为现在的流行清洁工具&#xff0c;它的魅力之处在于&#xff1a;性价比极高&#xff0c;大多数家庭无需花费过多就能把…

java的Filter(过滤器),Interceptor(拦截器) 和 Aspect(切面)

文章目录 前言一、过滤器 (Filter) 基本用法二、拦截器 (Interceptor) 基本用法三、Aspect(切面)的基本用法总结 前言 Filter 是servlet层面的&#xff0c;由Servlet容器(如Tomcat)支持&#xff0c;只能在web程序中使用&#xff0c;实现了javax.servlet.Filter接口 Intercept…

2024北京智源大会

北京智源大会是年度国际性人工智能高端学术交流的盛会&#xff0c;定位于内行的AI盛会。智源大会紧密围绕当前人工智能学术领域迫切需要解决的问题&#xff0c;以及产业落地过程中存在的诸多挑战&#xff0c;开展深入探讨。智源研究院是2018年11月份成立的一家人工智能领域的新…

直播美颜SDK技术指南:实现实时美颜效果的算法方案

本篇文章&#xff0c;小编将探讨直播美颜SDK的技术实现和算法方案。 一、美颜技术概述 美颜技术通过一系列图像处理算法&#xff0c;实时美颜效果可以在视频直播过程中实时呈现&#xff0c;提升用户的直播体验。为了实现这些效果&#xff0c;需要结合图像处理和计算机视觉技术…

“奇点”临近,产业应用与人工智能怎样“共同进化”

以下文章来源&#xff1a;新华日报 眼下&#xff0c;以大模型为核心的人工智能技术呈现颠覆性突破。年初&#xff0c;OpenAI公司发布旗下的文生视频大模型Sora&#xff0c;距去年ChatGPT的横空出世&#xff0c;也仅仅过去一年。 “当前&#xff0c;人工智能迈向通用智能‘奇点’…

Hue Hadoop 图形化用户界面 BYD

软件简介 Hue 是运营和开发 Hadoop 应用的图形化用户界面。Hue 程序被整合到一个类似桌面的环境&#xff0c;以 web 程序的形式发布&#xff0c;对于单独的用户来说不需要额外的安装。

綦江蜘蛛池四川官网下载

baidu搜索&#xff1a;如何联系八爪鱼SEO? baidu搜索&#xff1a;如何联系八爪鱼SEO? baidu搜索&#xff1a;如何联系八爪鱼SEO? CCSEO蜘蛛统计开发思路一般包括以下几个步骤: 定义需求:明确统计蜘蛛访问数据的目标和要求,例如需要获取哪些信息,统计的精度和频率等。 确定数…

springboot小型超市商品展销系统-计算机毕业设计源码01635

摘 要 科技进步的飞速发展引起人们日常生活的巨大变化&#xff0c;电子信息技术的飞速发展使得电子信息技术的各个领域的应用水平得到普及和应用。信息时代的到来已成为不可阻挡的时尚潮流&#xff0c;人类发展的历史正进入一个新时代。在现实运用中&#xff0c;应用软件的工作…

thinkphp5使用模型删除与复杂查询EXP

模型删除 应用软删除 表中需要有字段&#xff0c;deletetime 模型中使用下面方法 use SoftDelete;protected $deleteTime delete_time;真实删除 // 软删除 User::destroy(1); // 真实删除 User::destroy(1,true); $user User::get(1); // 软删除 $user->delete(); // 真…