C语言从入门到实践——常用字符函数和字符串函数的使用和模拟实现(2)

最全的Linux教程,Linux从入门到精通

======================

  1. linux从入门到精通(第2版)

  2. Linux系统移植

  3. Linux驱动开发入门与实战

  4. LINUX 系统移植 第2版

  5. Linux开源网络全栈详解 从DPDK到OpenFlow

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

第一份《Linux从入门到精通》466页

====================

内容简介

====

本书是获得了很多读者好评的Linux经典畅销书**《Linux从入门到精通》的第2版**。本书第1版出版后曾经多次印刷,并被51CTO读书频道评为“最受读者喜爱的原创IT技术图书奖”。本书第﹖版以最新的Ubuntu 12.04为版本,循序渐进地向读者介绍了Linux 的基础应用、系统管理、网络应用、娱乐和办公、程序开发、服务器配置、系统安全等。本书附带1张光盘,内容为本书配套多媒体教学视频。另外,本书还为读者提供了大量的Linux学习资料和Ubuntu安装镜像文件,供读者免费下载。

华为18级工程师呕心沥血撰写3000页Linux学习笔记教程

本书适合广大Linux初中级用户、开源软件爱好者和大专院校的学生阅读,同时也非常适合准备从事Linux平台开发的各类人员。

需要《Linux入门到精通》、《linux系统移植》、《Linux驱动开发入门实战》、《Linux开源网络全栈》电子书籍及教程的工程师朋友们劳烦您转发+评论

网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。

需要这份系统化的资料的朋友,可以点击这里获取!

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!

while (str[i])
{
	c = str[i];
	if (islower(c))
		c -= 32;
	putchar(c);
	i++;
}
return 0;

}


 ![](https://img-blog.csdnimg.cn/direct/b8c0f524ab5540df9239d55880d68f0f.png)


## 2. 字符转换函数


C语⾔提供了2个字符转换函数:



int tolower ( int c ); //将参数传进去的⼤写字⺟转⼩写
int toupper ( int c ); //将参数传进去的⼩写字⺟转⼤写


 上⾯的代码,我们将⼩写转⼤写,是-32完成的效果,有了转换函数,就可以直接使⽤ tolower 函 数。



#include <stdio.h>
#include <ctype.h>
int main()
{
int i = 0;
char str[] = “Test String.\n”;
char c;
while (str[i])
{
c = str[i];
if (islower©)
c = toupper©;
putchar©;
i++;
}
return 0;
}


 ![](https://img-blog.csdnimg.cn/direct/a1ec6d5e027f41a78e4dd695c606cd79.png)


## 3.strlen的使用和模拟实现



size_t strlen ( const char * str );


* 字符串以 '\0' 作为结束标志,strlen函数返回的是在字符串中 '\0' 前⾯出现的字符个数(不包 含 '\0' )。
* 参数指向的字符串必须要以 '\0' 结束。
* 注意函数的返回值为 size\_t,是⽆符号的( 易错 )
* strlen的使⽤需要包含头⽂件 • 学会strlen函数的模拟实现



#include <stdio.h>
#include <string.h>
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的模拟实现:


⽅式1:



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


⽅式2:



//不能创建临时变量计数器
int my_strlen(const char * str)
{
assert(str);
if(*str == ‘\0’)
return 0;
else
return 1+my_strlen(str+1);
}


⽅式3:



//指针-指针的⽅式
int my_strlen(char *s)
{
assert(str);
char *p = s;
while(*p != ‘\0’ )
p++;
return p-s;
}


## 4. strcpy 的使用和模拟实现



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


* 源字符串必须以 '\0' 结束。
* 会将源字符串中的 '\0' 拷⻉到⽬标空间。
* ⽬标空间必须⾜够⼤,以确保能存放源字符串。
* ⽬标空间必须可修改。


strcpy的模拟实现:



char* my_strcpy(char dest, const charsrc)
{
char *ret = dest;
assert(dest != NULL);
assert(src != NULL);

while((*dest++ = *src++))
{
;
}
return ret;
}


## 5. strcat 的使用和模拟实现



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


* 源字符串必须以 '\0' 结束。
* ⽬标字符串中也得有 \0 ,否则没办法知道追加从哪⾥开始。
* ⽬标空间必须有⾜够的⼤,能容纳下源字符串的内容。
* ⽬标空间必须可修改



char *my_strcat(char dest, const charsrc)
{
char *ret = dest;
assert(dest != NULL);
assert(src != NULL);
while(*dest)
{
dest++;
}
while((*dest++ = *src++))
{
;
}
return ret;
}


## 6. strcmp 的使用和模拟实现


* 第⼀个字符串⼤于第⼆个字符串,则返回⼤于0的数字
* 第⼀个字符串等于第⼆个字符串,则返回0
* 第⼀个字符串⼩于第⼆个字符串,则返回⼩于0的数字


strcmp函数的模拟实现:



int my_strcmp (const char * str1, const char * str2)
{
int ret = 0 ;
assert(str1 != NULL);
assert(str2 != NULL);
while(*str1 == *str2)
{
if(*str1 == ‘\0’)
return 0;
str1++;
str2++;
}
return *str1-*str2;
}


##  7. strncpy 函数的使用



char * strncpy ( char * destination, const char * source, size_t num );


* 拷⻉num个字符从源字符串到⽬标空间。
* 如果源字符串的⻓度⼩于num,则拷⻉完源字符串之后,在⽬标的后边追加0,直到num个。


##  8. strncat 函数的使用



char * strncat ( char * destination, const char * source, size_t num );


* 将source指向字符串的前num个字符追加到destination指向的字符串末尾,再追加⼀个 \0 字 符。
* 如果source 指向的字符串的⻓度⼩于num的时候,只会将字符串中到 \0 的内容追加到destination指向的字符串末尾。


## 9. strncmp函数的使用



int strncmp ( const char * str1, const char * str2, size_t num );


 ![](https://img-blog.csdnimg.cn/direct/b63e506cb09949ea88deb8921abca6d3.png)


## 10. strstr 的使用和模拟实现




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


* 函数返回字符串str2在字符串str1中第⼀次出现的位置
* 字符 串的⽐较匹配不包含 \0 字符,以 \0 作为结束标志



#include <stdio.h>
#include <string.h>
int main()
{
char str[] = “This is a simple string”;
char* pch;
pch = strstr(str, “simple”);
printf(“%s\n”, pch);
return 0;
}


 strstr的模拟实现:



char* my_strstr(const char* str1,const char* str2)
{
assert(str1 && str2);
const char* s1 = NULL;
const char* s2 = NULL;
const char* cur = str1;

while (*cur != '\0')
{
	s1 = cur;
	s2 = (char*)str2;
	while(*s1 != '\0' && *s2 != '\0' && *s1 == *s2)
	{
		s1++;
		s2++;
	}
	if (*s2 == '\0')
	{
		return (char*)cur;
	}
	cur++;
}
return NULL;

}
int main()
{
char arr1[] = “abcdefg”;
char arr2[] = “bcdc”;
char* ret = my_strstr(arr1, arr2);
if (ret == NULL)
{
printf(“没找到”);
}
else
{
printf(“%s\n”, ret);
}
return 0;
}


##  11. strtok 函数的使用




char * strtok ( char * str, const char * sep);


* sep参数指向⼀个字符串,定义了⽤作分隔符的字符集合
* 第⼀个参数指定⼀个字符串,它包含了0个或者多个由sep字符串中⼀个或者多个分隔符分割的标 记。
* strtok函数找到str中的下⼀个标记,并将其⽤ \0 结尾,返回⼀个指向这个标记的指针。(注: strtok函数会改变被操作的字符串,所以在使⽤strtok函数切分的字符串⼀般都是临时拷⻉的内容 并且可修改。)
* strtok函数的第⼀个参数不为 NULL ,函数将找到str中第⼀个标记,strtok函数将保存它在字符串 中的位置。
* strtok函数的第⼀个参数为 NULL ,函数将在同⼀个字符串中被保存的位置开始,查找下⼀个标 记。
* 如果字符串中不存在更多的标记,则返回 NULL 指针。



#include <stdio.h>
#include <string.h>
int main()

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前在阿里

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年最新Linux运维全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上运维知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以点击这里获取!

升又不知道该从何学起的朋友。**
[外链图片转存中…(img-5FltV0B9-1714845430413)]
[外链图片转存中…(img-ofFPB3IN-1714845430413)]
[外链图片转存中…(img-MLzRNCny-1714845430413)]
[外链图片转存中…(img-z5xgopHK-1714845430414)]
[外链图片转存中…(img-19pioCxm-1714845430414)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上运维知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以点击这里获取!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值