1.字符串
1.1语法
1.2语义
注意:
(1)字符串更关注的是字符串整体,而不是单个字符
(2)字符串的结束标志比较重要,表示字符串结束
(3)处理字符串时,常常使用结束标志【‘\0’】作为判断
2.字符串输入函数
2.1【gets】函数
2.1.1原型
【char *gets(char *s);】
2.1.2功能
输入字符串
2.1.3参数
存放字符串一块内存空间
2.1.4返回值
表示的是 存储字符串那块空间首地址
2.1.5使用规则
【gets】函数:为字符串输入函数,调用该函数时需给出字符串的存储地址,以回车(【'\n'】)作为字符串输入结束的标志,并将回车符转换成为【'\0'】。
【scanf】函数:以回车(【'\n'】)、空格(【' '】)或跳格(【'\t'】)作为字符串输入结束的标志;故而【scanf】不能输入有空格的字符串(用来输入一个单词或许不错哦)。
3.字符串输出函数
3.1【puts】函数
3.1.1原型
【int puts(const char *s);】
3.1.2功能
输出字符串
3.1.3参数
字符串所在空间的首地址
3.1.4返回值
int类型:
成功 >0
失败 -1
补充:
(1)输出时,自动换行
4.字符串长度统计函数
4.1【strlen】函数
4.1.1原型
【size_t strlen(const char *s);】
4.1.2功能
统计字符串长度
注意:
(1)统计字符串函数不会计算【'\0'】
区别:
【sizeof()】运算符会将【'\0'】计算在内
4.1.3参数
【s】:字符串地址
4.1.4返回值
返回值的类型:无符号整形【unsigned int】
5.字符串拼接函数
5.1【strcat】函数
5.1.1原型
【char *strcat(char *dest, const char *src);】
5.1.2功能
字符串拼接
5.1.3参数
【dest】:目标字符串
【src】:源字符串
5.1.4返回值
【成功】:返回的是【dest】
【失败】:【NULL】
6.字符串拷贝函数
6.1【strcpy】函数
6.1.1原型
【char *strcpy(char *dest, const char *src);】
6.1.2功能
实现字符串拷贝
6.1.3参数
【dest】:目标字符串
【src】:源字符串
6.1.4返回值
【成功】:返回的是【dest】地址
【失败】:【NULL】
7.字符串比较函数
7.1【strcmp】函数
7.1.1原型
【int strcmp(const char *s1, const char *s2);】
7.1.2功能
比较两个字符串
7.1.3参数
【s1】:
【s2】:
表示两个字符串
7.1.4返回值
【返回值】>0:s1>s2
【返回值】=0:s1=s2
【返回值】<0:s1<s2
注意:
返回值,实际上是,结束位置上字符的差值
8字符串解析
8.1【strtok】
8.1.1函数原型
【char *strtok(char *str, const char *delim);】
8.1.2函数功能
通过指定标记对源字符串进行分割
个人理解:以指定标记为结束点,剪切字符串
8.1.3函数参数
【str】:指定待解析的字符串;
如果随后的每次调用中要解析同一个字符串,【str】必须为【NULL】
【delim】:用于解析字符串的标记;
如果随后的每次调用中要解析同一个字符串,【delim】也可以被指定为不同的字符串
注意:
(1)第一次分割之后,原字符串str是分割完成之后的第一个字符串,剩余的字符串存储在一个静态变量中。
(2)【strtok】函数在提取字符串时使用了静态缓冲区,多线程同时访问该静态变量会造成线程安全问题。
(3)【strtok】函数遇到【标记】则将【标记】替换成【\0】;同时【strtok】函数内部遍历字符串的指针指向的是【标记】的下一个位置(也即下一次调用【strtok】的起始位置);【strtok】解析空字符串返回【NULL】。
(4)【strtok】函数直接在源字符串进行分割,所以在使用过程中应该注意源字符串会被修改的问题。
8.1.4返回值
【分割字串成功】:返回指向子串的指针
该指针指向的是子串在源字符串中的起始位置。
【空字符串】:返回【NULL】
8.2【strstr】
8.2.1函数原型
【char *strstr(const char *haystack, const char *needle);】
8.2.2函数功能
在字符串【haystack】中查找第一次出现字符串【needle】的位置
注意:
(1)不包含【\0】
8.2.3函数参数
【haystack】:要被检索的字符串
【needle】:在【haystack】字符串内要搜索的小字符串
8.2.4返回值
返回在【haystack】中第一次出现【needle】字符串的位置,即返回子字符串的首地址。(打印该地址上的字符串,则打印出该地址之后的母串的所有)
如果未找到则返回【NULL】