轻松拿捏C语言——【字符串函数】的使用及模拟实现

2024-06-04 4611阅读

轻松拿捏C语言——【字符串函数】的使用及模拟实现 第1张轻松拿捏C语言——【字符串函数】的使用及模拟实现 第2张🥰欢迎关注 轻松拿捏C语言系列,来和 小哇 一起进步!✊

🎉创作不易,请多多支持🎉

🌈感谢大家的阅读、点赞、收藏和关注💕

🌹如有问题,欢迎指正 感谢


目录

一、 strlen的使用和模拟实现

二、strcpy的使用和模拟实现

三、strcat的使用和模拟实现

四、strcmp的使用和模拟实现

五、strncpy的使用和模拟实现

六、strncat的使用和模拟实现

七、strncmp的使用和模拟实现

八、strstr的使用和模拟实现

九、strtok的使用和模拟实现

十、strerror的使用和模拟实现


一、 strlen的使用和模拟实现

size_t strlen ( const char * str );

注意: 

• 字符串以 '\0' 作为结束标志,strlen函数返回的是在字符串中 '\0' 出现前面的字符个数(不包含 '\0' )。

• 参数指向的字符串必须要以 '\0' 结束。

• 注意函数的返回值为 size_t,是无符号的( 易错 )

• strlen的使用需要包含头文件 

#include 
#include 
int main()
{
 const char* str1 = "abcdef";
 const char* str2 = "bbb";
 if(strlen(str2)-strlen(str1)>0)
 {
     printf("str2>str1\n");
 } 
 else
 {
     printf("srt1>str2\n");
 }
 return 0;
}

因为strlen返回值为无符号整型,所以if条件中的不是 3 - 6 = -3,而应该是-3的补码 一个大于0的数字,所以打印 str2>str1 

#include 
#include 
int main()
{
	//char arr[] = "abcdef";
	char arr[] = { 'a', 'b','c' };
	size_t len = strlen(arr);
	printf("%zd\n", len);
	return 0;
}

无\0,打印出的是随机值 

模拟实现

法一:计算器方式

//计数器⽅式
int my_strlen(const char * str)
{
 int count = 0;
 assert(str);
 while(*str)
 {
     count++;
     str++;
 }
 return count;
}

法二: 递归的方式

int my_strlen(const char * str)
{
 assert(str);
 if(*str == '
size_t my_strlen(const char* str)
{
	const char* start = str;
	assert(str != NULL);
	while (*str != '

二、strcpy的使用和模拟实现

') { str++; } return str - start; }
') return 0; else return 1+my_strlen(str+1); }

法三:指针相减

#include 
#include 
int main()
{
	char arr1[] = "hello world";
	char arr2[20] = {0};//1个元素
	
	strcpy(arr2, arr1);
	printf("%s\n", arr2);
 	return 0;
}
#include
#include
int main()
{
	char arr1[] = "hello world";
	char* p = "xxxxxxxxxxxxxxxxxxxx";//常量字符串-不能修改
	strcpy(p, arr1);//err
	printf("%s\n", p);
	return 0;
}

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

注意:

• 源字符串必须以 '\0' 结束。

• 会将源字符串中的 '\0' 拷贝到目标空间。

• 目标空间必须足够大,以确保能存放源字符串。

• 目标空间必须可修改。 

正确使用:

char* my_strcpy(char* dest, const char* src)
{
	//assert(dest != NULL);
	//assert(src != NULL);
	assert(dest && src);
	char* ret = dest;
	while (*src != '
char* my_strcpy(char* dest, const char* src)
{
	//assert(dest != NULL);
	//assert(src != NULL);
	assert(dest && src);
	char* ret = dest;
	while (*dest++ = *src++)//拷贝过去字符后,判断表达式的值,当

三、strcat的使用和模拟实现

拷贝过去后,判断为假,停止循环 { ; } return ret;//返回目标空间的起始地址 }
') { *dest = *src; src++; dest++; } *dest = *src;//拷贝
char * strcat ( char * destination, const char * source );
return ret;//返回目标空间的起始地址 }

错误使用:

int main()
{
	char arr1[20] = "he
#include
#include
//要返回目标空间的起始地址
char* my_strcat(char* dest, const char* src)
{
	char* ret = dest;
	assert(dest && src);
	//1. 找目标空间的

四、strcmp的使用和模拟实现

while (*dest != '
int strcmp ( const char * str1, const char * str2 );
') dest++; //2. 拷贝 while (*dest++ = *src++) ; return ret; }
lloxxxxx"; char arr2[] = "world"; strcat(arr1, arr2);//字符串追加 printf("%s\n", arr1); return 0; }

模拟实现: 

strcpy函数返回的是目标空间的起始地址

#include
#include
 int main()
{
	char arr1[] = "abq";
	char arr2[] = "abcdef";
	int ret = strcmp(arr1, arr2);
	//printf("%d\n", ret);
	if (ret >0)
	{
		printf(">\n");
	}
	else
	{
		printf("

优化:

注意:

• 源字符串必须以 '\0' 结束。

• 目标字符串中也得有 \0 ,否则没办法知道追加从哪里开始。

• 目标空间必须有足够的大,能容纳下源字符串的内容。

• 目标空间必须可修改。

• 字符串自己给自己追加,如何?不能保证 

使用:

从第一个\0开始追加

轻松拿捏C语言——【字符串函数】的使用及模拟实现 第3张

模拟实现:

注意:

第⼀个字符串大于第⼆个字符串,则返回大于0的数字 ◦

第⼀个字符串等于第⼆个字符串,则返回0 ◦

第⼀个字符串小于第⼆个字符串,则返回小于0的数字 ◦

(在vs上,大于0返回的1,小于0返回的-1)

那么如何判断两个字符串? 比较两个字符串中对应位置上字符ASCII码值的大小。 

使用:


    免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

    目录[+]