string.h函数:
1.strlen 数出字符串存在多少字符;

2.strcmp 比较两个字符串,若相等返回0不相等返回1

3.strcpy(char *restrict dst,const char *restrict src);

//以上为strcpy函数的原型声明
作用:将dst字符串用src字符串覆盖,并且返回dst
restrict:表明dst不可与src不重叠

操作如下:
char dst=(char)malloc(strlen(src)*sizeof(char)+1);
strcpy(dst,src);

{(补充:malloc–>需要调用#include<strlib.h>,并且需要用指针变量来储存malloc返回的值)
malloc是向计算机要一块空间,返回的类型为void

举例:如果需要一个N个int的空间,我们需要使用malloc动态内存分配

操作如下:

include<stdio.h>

include<stdlib.h>

int main(void){
int N,p;
scanf(“%d”,&N);
p=(int
)malloc(N*sizeof(int));–>是向计算机要了一块N个int
的空间

free(p);-->释放空间内存

}
}

4.strcat(char*restrict s1,const char *restrict s2);

//以上是strcat函数的原型声明
作用:将s2拷贝到s1的后面,接成一个长字符串 然后返回s1(s1必须有足够的空间)

5.strchr(const chars,int c); //返回一个指针
strrchr(const char
s,int c);

//以上为函数的原型声明
作用:strchr是从左边开始查找第一个为c的字符
strrchr是从右边开始查找第一个为c的字符
返回NULL表示没有找到

//使用小技巧:
(1).寻找第二个重复的字符:
char s[]=”hello”;
char *p=strchr(s,’l’);//此时输出p会得到llo。
p=strchr(p+1,’l’); //此时p指向了llo让他+1指向lo,再从lo里找到l。

(2).将字符串的一部分提出来,放在另外一处去
char s[]=”hello”;
char *p=strchr(s,’l’);
char t=(char)malloc(strlen(p)+1);
strcpy(t,p);
printf(“%s”,t);
free(t);

//上面操作是将字符串s的“llo”提取出来放在了指针t的位置;

(3).得到一串字符串的前几个字符
char s[]=”hello”;
char p=strchr(s,’l’);
char c=
p;//此时*p指向了数组s的第一个l的位置
*p=’\0′;//让第一个l的位置变成了\0 则s数组就变成了he\0lo\0;
char t=(char)malloc(strlen(s)+1);
strcpy(t,s);//用新的指针来储存改变后的字符串s
printf(“%s\n”,t);
p=c;//还原p所指向的数组s的位置;
free(t);

6.char *strstr(const char *s1,const char *s2)
char *strcasestr(const char *s1,const char *s2)

//以上为函数的原型声明
作用为:第一个为在字符串中寻找字符串,第二个是在字符串中寻找字符串的过程中忽略大小写。

补充:对于strcpy和strcat有更安全的版本

char *strncpy(char *restrict dst,const char *restrict src,size_t n); n–>表示可以替换的最大字符数量

char *strncat(char *restrict s1,const char *restrict s2,size_t n); n–>表示可以后缀的最大字符数量

其次对于 int strncmp(const chars1,const chars2,size_t n);
n–>表示依次判断字符串s1前n个字符是否为a,b,c…,n

版权声明:本文为Kk--原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/Kk--/p/13904067.html