【字符函数与字符串函数】

news2024/11/15 14:06:08

文章目录

  • 一、strlen函数
      • 1.strlen函数的使用
      • 2.strlen函数的模拟实现
        • (1)计算器办法
        • (2)不创建临时变量计数器
        • (3)指针
  • 二、strcpy函数
      • 1、strcpy函数的使用
      • 2、strcpy函数的模拟实现
  • 三、strcat函数
      • 1、strcat函数的使用
      • 2、strcat模拟实现
      • 3、字符串自己给自己追加?
  • 四、strcmp函数
      • 1、strcmp函数的使用
      • 2、strcmp函数的模拟实现
  • 五、strncpy函数
      • 1、strcnpy函数的使用
      • 2、strncpy的模拟实现
  • 六、strncat函数
      • 1、strncat函数的使用
      • 2、strncat函数的模拟实现
  • 七、strncmp函数
      • 1、strncmp函数的使用
      • 2、strncmp函数的模拟实现

一、strlen函数

1.strlen函数的使用

  • 字符串是以'\0'为结束标志,strlen是统计的'\0'前面的字符个数,不包括'\0'
  • 函数的返回值是size_t,无符号的
  • 参数指向的字符串必须要包含'\0'
  • strlen需要包含头文件<string.h>
#include<stdio.h>
#include<string.h>
int main()
{
	char arr[100] = { "xiaowang,nihenhao" };
	size_t ret = strlen(arr);
	printf("%d ", ret);
	return 0;
}

2.strlen函数的模拟实现

(1)计算器办法
#include<stdio.h>
#include<assert.h>
int my_strlen(const char* str)   //const——不改变我arr中的字符串内容
{
	size_t count = 0;
	assert(str);   //断言
	while (*str != '\0')
	{
		count++;
		str++;
	}
	return count;
}
int main()
{
	char arr[100] = "hello,nicwe";
	size_t ret = my_strlen(arr);
	printf("%d ", ret);
	return 0;
}
(2)不创建临时变量计数器
#include<stdio.h>
#include<assert.h>
int my_strlen(const char* str)
{
	assert(str);
	if (*str == '\0')
		return 0;
	else
	{
		return 1 + my_strlen(str + 1);
	}
}
int main()
{
	char arr[100] = "hello,world!";
	size_t ret = my_strlen(arr);
	printf("%d ", ret);
	return 0;
}
(3)指针
#include<stdio.h>
#include<assert.h>
int my_strlen(const char* str)
{
	assert(str);
	char* p = str;
	while (*p != '\0')
	{
		p++;
	}
	return p - str;
}
int main()
{
	char arr[100] = "hello world!";
	size_t ret = my_strlen(arr);
	printf("%d ", ret);
	return 0;
}

二、strcpy函数

1、strcpy函数的使用

在这里插入图片描述

  • 源字符串中必须是'\0'结束
  • 将源字符串中的'\0'拷贝到目标空间
  • 目标空间要求足够大,可以容纳下源字符串
  • 目标空间要求是可以修改的
  • 需要包含头文件<string.h>
#include<stdio.h>
#include<string.h>
int main()
{
	char arr[] = "hello,";
	char str[20] = { 0 };
	strcpy(str,arr);
	printf("%s ", str);
	return 0;
}
     strcpy(str,arr);//str就是我们的目标空间,arr就是我们的源字符串
                     //这里是指arr中的字符串拷贝到str中

2、strcpy函数的模拟实现

#include<stdio.h>
#include<string.h>
#include<assert.h>
char* my_strcpy(char* p1, const char* p2)
{
	assert(p2,p1);
	char* str1 = p1;

	//拷贝的是'\0'之前的字符

	while (*p2 != '\0')
	{
		*p1++ = *p2++;
	}
	*p1 = '\0';//把'\0'拷贝到最后
	return str1;
}
int main()
{
	char arr[20] = "hello";
	char str[20] = { 0 };
	char* ret = my_strcpy(str, arr);
	printf("%s ", ret);
	return 0;

三、strcat函数

1、strcat函数的使用

在这里插入图片描述

  • 源字符串必须以'\0'结束
  • 目标字符串中需要用'\0',否则不知道源字符串追加到哪里
  • 目标字符串的空间需要足够的大,要能够容纳下源字符串
  • 目标空间必须修改
  • 需要头文件<string.h>
#include<stdio.h>
#include<string.h>
int main()
{
	char arr[20] = "hello,";
	char str[20] = "world";
	strcat(arr, str);
	printf("%s ", arr);
	return 0;
}

2、strcat模拟实现

#include<stdio.h>
#include<assert.h>
char* my_strcat(char* p1, const char* p2)
{
	assert(p1, p2);
	char* str1 = p1;
	while (*p1 != '\0')
	{
		p1++;
	}
	while (*p2 != '\0')
	{
		*p1++ = *p2++;
	}
	*p1 = '\0';
	return str1;
}
int main()
{
	char arr[20] = "hello,";
	char str[10] = "world";
	char* ret = my_strcat(arr, str);
	printf("%s ", ret);
	return 0;
}

3、字符串自己给自己追加?

首先我们可以直接使用一下strcat函数看看:

#include<stdio.h>
#include<string.h>
int main()
{
	char arr[200] = "hello,";
	strcat(arr, arr);
	printf("%s ", arr);
	return 0;
}

结果我们是可以得到hello,hello,的。

但是,当我们自己以上面的形式进行模拟实现时,我们可以发现,模拟实现的并没有成功,因为比标准库函数会进行错误处理,确保不会放生缓冲区溢出等问题,所以我们自己写的模拟实现仅仅只是一个参考,至于标准库函数是怎么实现的,我们也是不得而知的。

四、strcmp函数

1、strcmp函数的使用

在这里插入图片描述

  • 标准规定:

  • 当第一个字符串大于第二个字符串时,返回一个大于0的数字

  • 当第一个字符串小于第二个字符串时,返回一个小于0的数字

  • 当第一个字符串与第二个字符串相等时,返回0

在这里插入图片描述

  • 判断两个字符串的本质:
    就是比较两个字符串的ASCII码值的大小
#include<stdio.h>
#include<string.h>
int main()
{
	char arr[20] = "adcgft";
	char str[20] = "gdhuo";
	int ret=strcmp(arr, str);
	if (ret > 0)
	{
		printf("大的是%s ", arr);
	}
	else if (ret < 0)
	{
		printf("大的是%s ", str);
	}
	else
		printf("一样大小\n");
	return 0;
}

输出的是gdhuo,因为g的ASCII码值大于a,所以字符串str大于arr。

2、strcmp函数的模拟实现

int my_strcmp(const char* p1, const char* p2)
{
	assert(p1, p2);
		while (*p1 ==*p2)
		{
			if (*p1 == '\0')
				return 0;
				p1++;
				p2++;
			
		}
		return *p1 - *p2;
}
int main()
{
	char arr[29] = "asdftgh";
	char str[20] = "asdft";
	int ret = my_strcmp(arr, str);
	printf("%d \n", ret);
	if (ret > 0)
	{
		printf("大的是%s \n", arr);
	}
	else if (ret < 0)
	{
		printf("大的是%s \n", str);
	}
	else
		printf("一样大小\n");
	return 0;
}

我们这里的ret等于103就可以知道,两个字符串比较大小,使用strcmp函数返回的是ASCII码值的差值。

五、strncpy函数

在这里插入图片描述

相比较于strcpy,两个字母相差与一个字母n,两者的作用本质上是一样的。

1、strcnpy函数的使用

在这里插入图片描述

  • 拷贝从源字符串中的num个字符到目标空间中
  • 如果源字符串没有num个字符,则在后面追加0,直到凑为num个数
#include<stdio.h>
#include<string.h>
int main()
{
   char arr[20] = "hello,world";
   char str[30] = { 0 };
   strncpy(str, arr, 19);
   printf("%s \n", str);
   return 0;
}

2、strncpy的模拟实现


#include<stdio.h>
#include<assert.h>
char* my_strncpy(char* p1, const char* p2,size_t n)
{
	assert(p1, p2);
	char* dest = p1;
	while (n&&*p1=='\0')
	{
		*p1 = *p2;
		p1++;
		p2++;
		n--;
	}
	if (n > 0)
	{
		*p1 = '\0';
	}
	return dest;
}
int main()
{
	char arr[] = "helllow";
	char str[20] = { 0 };
	char* ret = my_strncpy(str, arr, 5);
	printf("%s \n", ret);
	return 0;
}

六、strncat函数

1、strncat函数的使用

在这里插入图片描述

  • 相差与strcat函数的功能只多了个size_t num——是指source中的字符追加num个到destination中,最后还会再追加个'\0'
  • 同时也需要包含头文件<string.h>
    在这里插入图片描述
#include<stdio.h>
#include<string.h>
int main()
{
	char arr[30] = "hello,";
	char str[10] = "world,li";
	strncat(arr, str, 5);
	printf("%s ", arr);
	return 0;
}

在这里插入图片描述

2、strncat函数的模拟实现

在这里插入图片描述
返回的是目标数组的地址

#include<stdio.h>
#include<assert.h>
char* my_strncat(char* p1, char* p2, size_t m)
{
	assert(p1, p2);//断言——看传递是否是野指针
	int* ret = p1;
	while (*p1 != '\0')
	{
		p1++;
	}
	while (*p2 != '\0' && m != 0)
	{
		*p1 = *p2;
		p1++;
		p2++;
		m--;
	}
	if (m > 0)
	{
		*p1 = '\0';
	}
	return ret;
}
int main()
{
	char arr[40] = "hello,";
	char str[20] = "world,liming";
	my_strncat(arr, str, 4);
	printf("%s ", arr);
	return 0;
}

其中结果是hello,worl

七、strncmp函数

1、strncmp函数的使用

  • strncmp函数和strcmp函数道理一样,都是比较字符串的大小,而strncmp函数是比较前num个字符的大小。(最多比较num个)
  • 如果提前发现不一样,就提前结束;如果num个字符的比较完了且相等,那么返回0.
    在这里插入图片描述
    在这里插入图片描述
#include<stdio.h>
int main()
{
	char arr[20] = "qieyouyou";
	char str[20] = "qiekenao";
	int ret=strncmp(arr, str, 5);
	printf("%d ", ret);
	return 0;
}

结果是返回大于1的数字,说明arr数组的前5个字符大于str数组的前5个字符

2、strncmp函数的模拟实现

#include<stdio.h>
#include<assert.h>
int my_strncmp(const char* p1, const char* p2, size_t n)
{
	assert(p1, p2);
	while (n != 0)
	{
		while (*p1 != '\0' && *p2 != '\0' && n != 0)
		{
			if (*p1 == *p2) 
			{
				p1++;
				p2++;
			}
			n--;
		}
		return *p1 - *p2;
	}
	if (n == 0)
	{
		return 0;
	}
}
int main()
{
	char arr[20] = "qieyouypou";
	char str[20] = "qieyoumij";
	int ret = my_strncmp(arr, str, 7);
	printf("%d ", ret);
	return 0;
}

好了,今天就到这里啦,后续我还会继续更新的,最近有一丢丢的忙,更新比较慢(望谅解!)

老规矩附上一张好看的图片(祝愿大家找到自己人生中想要的东西,加油哦!!!)

在这里插入图片描述

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

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

相关文章

2024年数维杯数学建模

高质量原创论文已完成 需要的私我

构建内网yum仓库

1、环境介绍 系统&#xff1a;龙蜥os 7.9 2、安装epel源 yum install epel-release -y3、安装nginx服务器并启动 yum install nginx httpd -y配置 server {listen 80;server_name repo.wtown.com;root /usr/share/nginx/html/repo;index index.html index.htm;location / {…

信息安全-古典密码学简介

目录 C. D. Shannon: 一、置换密码 二、单表代替密码 ① 加法密码 ② 乘法密码 ③密钥词组代替密码 三、多表代替密码 代数密码 四、古典密码的穷举分析 1、单表代替密码分析 五、古典密码的统计分析 1、密钥词组单表代替密码的统计分析 2、英语的统计规…

报表-集成

1、部署报表服务器 以centos为例 1.1 将服务拷贝到服务器 其中JDK-17是对应平台的jdk 1.2 修改lite-report下的source.config 1.3 把设计好的报表文件拷贝到lite-report/report 1.4 启动服务&#xff1a;sh run.sh restart 2、使用Nginx location /litereport/ { …

前端笔记-day1

文章目录 01-标签的写法02-HTML的基本骨架03-标签的关系04-注释05-标题标签06-段落标签07-换行与水平线标签08-文本格式化标签09-图像的基本使用10-图像的属性12-绝对路径13-超链接14-音频15-视频标签16-招聘案例18-个人简历19-vue简介 01-标签的写法 <strong>文字内容&…

LabVIEW开发MOOG控制系统数据处理软件

LabVIEW开发MOOG控制系统数据处理软件 在现代航空领域&#xff0c;飞机结构的静强度试验是保证飞机安全运行的关键环节。MOOG加载控制系统作为试验中的关键设备&#xff0c;其数据输出的直观性和易处理性对于提高试验效率具有重要意义。设计了一种基于LabVIEW的MOOG控制系统数…

##15 探索高级数据增强技术以提高模型泛化能力

文章目录 前言数据增强的重要性常见的数据增强技术高级数据增强技术在PyTorch中实现数据增强结论 前言 在深度学习领域&#xff0c;数据增强是一种有效的技术&#xff0c;它可以通过在原始数据上应用一系列变换来生成新的训练样本&#xff0c;从而增加数据的多样性&#xff0c…

Redis过期删除策略和内存淘汰策略有什么区别?

Redis过期删除策略和内存淘汰策略有什么区别&#xff1f; 前言过期删除策略如何设置过期时间&#xff1f;如何判定 key 已过期了&#xff1f;过期删除策略有哪些&#xff1f;Redis 过期删除策略是什么&#xff1f; 内存淘汰策略如何设置 Redis 最大运行内存&#xff1f;Redis 内…

ADS基础介绍篇1

一. ADS简介 常用的射频仿真软件有ADS和AWR&#xff0c;ADS(Advanced Design system)最传统&#xff0c;是Agilent公司于2008年推出的电磁场仿真器&#xff0c;可提供原理图设计和layout版图设计。仿真功能十分强大&#xff0c;可提供从无源到有源&#xff0c;从直流到交流&am…

算法提高之矩阵距离

算法提高之矩阵距离 核心思想&#xff1a;多源bfs 从多个源头做bfs&#xff0c;求距离 先把所有1的坐标存入队列 再把所有1连接的位置存入 一层一层求 #include <iostream>#include <cstring>#include <algorithm>using namespace std;const int N 1…

关于画图-一次性搞定各类高级论文作图及配色

关于画图-一次性搞定各类高级论文作图及配色 图&#xff08;Figure&#xff09;可以让各类论文的结果更加直观&#xff0c;有时候一张图片比一大段文字更有说服力。 但许多新手作者可能会有一连串的疑惑&#xff1a;数据这么多&#xff0c;什么时候该做什么类型的图&#xff…

NASA数据集——2002-2011年全球18.7 至 89.0 千兆赫的亮度温度、海冰浓度和海冰积雪深度三级网格产品(AE_SI12)数据

AMSR-E/Aqua Daily L3 12.5 km Brightness Temperature, Sea Ice Concentration, & Snow Depth Polar Grids V003 三级网格产品&#xff08;AE_SI12&#xff09;包括 18.7 至 89.0 千兆赫的亮度温度、海冰浓度和海冰积雪深度。 简介 美国国家航空航天局地球观测系统 Aqu…

##16 利用迁移学习和微调提升深度学习模型性能

文章目录 前言什么是迁移学习&#xff1f;迁移学习的主要优势迁移学习的策略1. 特征提取器2. 微调 在PyTorch中实现迁移学习环境设置加载预训练模型修改模型以适应新任务训练和微调模型迁移学习的示例应用 结论 前言 在深度学习的多个领域中&#xff0c;迁移学习技术已经成为了…

现代信号处理9_正则化(CSDN_20240512)

正则化的引入 解线性方程组&#xff1a; 这项工作有很多种做法&#xff0c;下面介绍两种&#xff0c;如下图所示&#xff0c;有一些数据点需要拟合&#xff0c;拟合的方法有很多。 1&#xff09; 构造线性函数①&#xff0c;这种函数比较简单&#xff0c;此时 2&#xff09; 构…

信息系统项目管理师0102:可行性研究的内容(7项目立项管理—7.2项目可行性研究—7.2.1可行性研究的内容)

点击查看专栏目录 文章目录 7.2项目可行性研究7.2.1可行性研究的内容1.技术可行性分析2.经济可行性分析3.社会效益可行性分析4.运行环境可行性分析5.其他方面的可行性分析记忆要点总结7.2项目可行性研究 可行性研究是在项目建议书被批准后,从技术、经济、社会和人员等方面的条…

46 udp网络程序

查询网络服务的命令 netstat -nlup n: 显示数字 a&#xff1a;显示所有 u&#xff1a;udp服务 p&#xff1a;显示pid Recv-Q收到的数量&#xff0c;本地ip和远端ip&#xff0c;00表示可以收到任何地址 网络聊天 服务端 定义一个server类&#xff0c;成员保存ip地址&#xff…

JAVA毕业设计138—基于Java+Springboot+Vue的医院预约挂号小程序(源代码+数据库)

毕设所有选题&#xff1a; https://blog.csdn.net/2303_76227485/article/details/131104075 基于JavaSpringbootVue的医院预约挂号小程序(源代码数据库)138 一、系统介绍 本系统前后端分离带小程序和后台 小程序&#xff08;用户端&#xff09;&#xff0c;后台管理系统&a…

SQLite性能测试(插入)

最近一直在思考一个问题&#xff0c;SQLite 做到这么轻量级&#xff0c;那它注定不会像 MySql 一样强性能&#xff0c;那么它的性能怎么样呢&#xff1f;并发量多高呢&#xff1f; 官方解释&#xff1a; About SQLite 最大数据库大小&#xff1a;281TB 最大行大小&#xff1…

LVDS 接口标准和规范

低压差分信号具有传输速率快、抗干扰性强的特点&#xff0c;是现在广泛应用的数据接口标准之一。Xilinx FPGA支持LVDS电平标准&#xff0c;并提供了动态相位调整解决方案&#xff0c;解决了基于LVDS源同步传输时存在的数据偏斜问题。 1 LVDS 技术规范简介 随着接口和背板信号…

最新巨量X-Bogus、_signature参数逆向分析与算法还原

文章目录 1. 写在前面2. 接口分析3. 断点分析4. 扣代码补环境5. 数据解密 【&#x1f3e0;作者主页】&#xff1a;吴秋霖 【&#x1f4bc;作者介绍】&#xff1a;擅长爬虫与JS加密逆向分析&#xff01;Python领域优质创作者、CSDN博客专家、阿里云博客专家、华为云享专家。一路…