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

一、字符串函数

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

 

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

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

相关文章

Spring AI 接入OpenAI实现文字生成图片功能

Spring AI 框架集成的图片大模型 2022年出现的三款文生图的现象级产品&#xff0c;DALL-E、Stable Diffusion、Midjourney。 OpenAI dall-e-3dall-e-2 Auzre OpenAI dall-e-3dall-e-2 Stability stable-diffusion-v1-6 ZhiPuAI cogview-3 OpenAI 与 Auzer OpenAI 使用的图片…

接口自动化测试工程化——了解接口测试

什么是接口测试 接口测试也是一种功能测试 我理解的接口测试&#xff0c;其实也是一种功能测试&#xff0c;只是平时大家说的功能测试更多代指 UI 层面的功能测试&#xff0c;而接口测试更偏向于服务端层面的功能测试。 接口测试的目的 测试左移&#xff0c;尽早介入测试&a…

6.归并+快排

5. 归并排序 核心思想 将无序数组从中间分为左右两个部分&#xff0c;分别给左右两个部分排序&#xff0c;排序以后把两个有序区间进行合并 把数组从中间分为左右两部分分别对前后两部分进行排序将排好序的两部分合并 包含两个部分&#xff1a;拆解阶段和合并阶段 归并排序…

跨平台看抖音、哔哩哔哩、虎牙、斗鱼啦,一个app即可完成

一、简介 1、一款免费、开源、无广告、跨平台的,可以观看抖音、哔哩哔哩、虎牙、斗鱼等平台的直播内容的软件。它简单好用,支持 Windows、MacOS、Linux、Android、iOS 等平台。 二、下载 1、文末有下载链接,apk手机可直接安装,不明白可以私聊我哈(麻烦咚咚咚,动动小手给个…

详解QFileSystemModel的使用

在Qt应用程序开发中&#xff0c;QFileSystemModel是一个强大的类&#xff0c;用于展示和操作文件系统的信息。它基于标准的QAbstractItemModel&#xff0c;提供了浏览本地文件系统目录树的能力&#xff0c;并且能够自动更新以反映文件系统的变化。本文将详细讲解QFileSystemMod…

MongoDB——写入耗时

mongodb写入10万条数据的耗时差不多是1s import time import pymongo from pymongo import MongoClient# 连接到MongoDB client MongoClient(mongodb://localhost:27017/) db client[test_db] collection db[test_collection]# 生成10万条数据 documents [{"name&quo…

ThinkPHP内核在线客服系统源码多商户版 对接适用场景(PC+WAP+公众号)

源码介绍 大部分站长都了解美洽系统&#xff0c;就跟这种类似的&#xff0c;可以实现一行代码接入客服&#xff0c;非常舒服&#xff0c;支持无限客服&#xff0c;无限坐席! 私有化源码部署&#xff0c;数据可控&#xff0c;稳定可靠。可自定义版权、logo。支持网页、微信公众…

CPN tools学习——可执行的 PN

目录 1添加令牌 2.转换防护Guard 1添加令牌 左侧新建颜色集和变量的声明定义&#xff1a; 为库所分配颜色集&#xff1a;左键tab键 P1处&#xff1a;添加多重集合&#xff0c;表示添加了两个令牌&#xff0c;第一个令牌值为A&#xff0c;第二个为B。 P2处&#xff1a;表示…

docker的教程长亭

把我的常用docker写在这里 之前用 vul - hub 靶场经常用 现在docker不知道为什么挂了 开启 docker-compose up -d 关闭 docker-compose down docker ps 只是运行 docker ps -a 所有 包括停止 docker ps -q 只看id docker stop <container_name_or_id> docker 的容器…

辣椒属2个T2T基因组-文献精读23

Two telomere-to-telomere gapless genomes reveal insights into Capsicum evolution and capsaicinoid biosynthesis 两个端粒到端粒无缝基因组揭示了辣椒进化和辣椒素生物合成的相关见解 摘要 辣椒&#xff08;Capsicum&#xff09;因其果实中含有辣椒素而闻名&#xff0c…

zabbix自定义监控mysql状态和延迟

zabbix自定义监控mysql状态和延迟 文章目录 zabbix自定义监控mysql状态和延迟zabbix自定义监控mysql状态配置主从配置自定义监控添加监控项添加触发器模拟测试异常 zabbix自定义监控mysql延迟配置自定义监控添加监控项添加触发器测试 zabbix自定义监控mysql状态 配置主从 1.安…

【区间合并 差分 栈】3169. 无需开会的工作日

本文涉及知识点 区间合并 差分数组&#xff08;大约2024年7月1号发) LeetCode3169. 无需开会的工作日 给你一个正整数 days&#xff0c;表示员工可工作的总天数&#xff08;从第 1 天开始&#xff09;。另给你一个二维数组 meetings&#xff0c;长度为 n&#xff0c;其中 me…

蓝牙模块的安全性与隐私保护

蓝牙模块作为现代无线通信的重要组成部分&#xff0c;在智能家居、可穿戴设备、健康监测等多个领域得到了广泛应用。然而&#xff0c;随着蓝牙技术的普及&#xff0c;其安全性和隐私保护问题也日益凸显。本文将探讨蓝牙模块在数据传输过程中的安全性问题&#xff0c;分析隐私保…

Web应用安全测试-业务功能滥用(二)

Web应用安全测试-业务功能滥用&#xff08;二&#xff09; 7、未验证的URL跳转 漏洞描述&#xff1a;服务端未对传入的跳转url变量进行检查和控制&#xff0c;可能导致可恶意构造任意一个恶意地址&#xff0c;诱导用户跳转到恶意网站。由于是从可信的站点跳转出去的&#xff…

如何扩展自己的外部竞争力

前言 程序员是一个需要不断学习的职业&#xff0c;面对层出不穷的新技术&#xff0c;假如你不能够保持一个不断学习的热情。那么&#xff0c;在未来的就业市场中&#xff0c;可能优势会不太明显。那么&#xff0c;除了提高自己内部的技术竞争力外&#xff0c;有什么渠道可以提…

Linux下的GPIO编程

目录 一、前言 二、sysfs方式 1、sysfs简介 2、基本目录结构 3、编号计算 4、sysfs方式控制GPIO 三、libgpiod库 1、libgpiod库简介 2、API函数 四、LED灯编程 一、前言 在Linux下&#xff0c;我们通常使用 sysfs 和 libgpiod库 两种方式进行控制GPIO&#xff0c;目前…

哈喽GPT-4o——对GPT-4o Prompt的思考与看法

目录 一、提示词二、提示词的优势1、提升理解能力2、增强专注力3、提高效率 三、什么样的算无效提示词&#xff1f;1、过于宽泛2、含糊不清3、太过复杂4、没有具体上下文5、缺乏明确目标6、过于开放7、使用专业术语但未定义8、缺乏相关性&#xff1a; 四、提示词正确的编写步骤…

ofd文件预览

文件列表 <template><div><div classfile v-if$myUtils.coll.isNotEmpty(filesList)><div classfile-view><div classfile-view-item :style{justifyContent: align } v-for(item, index) in filesList :keyindex><img classfile-view-item-…

纵深发力 持续推进,富格林平台发展势头喜人

自2024年2月1日正式上线以来,富格林互联网投融资平台已迅速崛起,吸引了业内专家学者的高度认可以及广大投资者的青睐。平台规模持续扩大,目前累计注册用户已超过10万人,总投资额突破50亿美元。这一卓越表现不仅体现了平台的稳健运营和出色的投资项目,也展示了其在互联网投融资领…

产品应用 | 小盒子跑大模型!英码科技基于算能BM1684X平台实现大模型私有化部署

当前&#xff0c;在人工智能领域&#xff0c;大模型在丰富人工智能应用场景中扮演着重要的角色&#xff0c;经过不断的探索&#xff0c;大模型进入到落地的阶段。而大模型在落地过程中面临两大关键难题&#xff1a;对庞大计算资源的需求和对数据隐私与安全的考量。为应对这些挑…