-
2、memmove
-
3、memcmp
-
4、memset
1、strlen
//函数原型
#include <string.h>
size_t strlen ( const char * str );
注释: strlen函数是用来计算字符串的 长度 (单词 length), 形参部分没得说,就是一个char*的指针, 特别注意的是这个返回值是size_t。
strlen函数计算的是字符串中字符的个数,我们都知道字符串的结束标志是**‘\0’**, 例如 :
#include <stdio.h>
#include <string.h>
int main()
{
char s1[] = “hello”;
printf(“strlen: %d\n”,strlen(s1));
printf(“sizeof: %d\n”,sizeof(s1));
return 0;
}
上面计算的结果如下:
大家一定要区别 strlen 与 sizeof 二者之间的区别,一个是计算字符串长度,另外一个是计算所占的空间大小,单位字节。
2、strcpy
#include <string.h>
char* strcpy( char *Destination, const char *Source );
注释: strcpy函数是用来 拷贝 字符串 (单词 copy),形参部分: char* destination,目的地嘛, char* source,数据源地。就是将第二个指针指向的内存的数据拷贝到 第一个指针指向的内存空间。 返回值是一个char*,返回的就是拷贝之后,destination 的起始地址。
值得注意的几点是:
-
source 源字符串必须以 **’\0’**为结束。
-
拷贝时,也会将source 里面的**’\0’**拷贝大destination里面去。
-
目的地destination的空间必须足够大。
#include <stdio.h>
#include <string.h>
int main()
{
char dest[20] = “################”;
char src[10] = “hello”;
printf(“拷贝之前: %s\n”, dest);
strcpy(dest, src);
printf(“拷贝之后: %s\n”, dest);
return 0;
}
运行结果如下:
3、strncpy
#include <string.h>
char* strncpy( char *Dest, const char *Source, size_t count );
注释: strncpy函数只是在strcpy函数的基础之上进行的完善,只是多了一个count参数,就是需要拷贝count个字符,具体的看代码:
#include <stdio.h>
#include <string.h>
int main()
{
char dest[20] = “################”;
char src[20] = “hello world”;
printf(“拷贝之前: %s\n”, dest);
strncpy(dest, src, 5);
printf(“拷贝之后: %s\n”, dest);
return 0;
}
运行结果如下:
值得注意的是: 这里hello拷贝完之后,dest数组最开始的那些‘#’ 还是在的,因为在拷贝hello时,只是拷贝了这5个字符,并没有拷贝’\0’,所以在输入的时候,还是把最开始的那些‘#’,输出了。如果源字符串的长度小于count,则拷贝完源字符串之后,在目标的后边追加0,直到count个。
4、strcmp
#include <string.h>
int strcmp( const char *string1, const char *string2 );
注释: strcmp函数,就是用于 比较 两个字符串的大小。可能你就会有疑问,两个字符串怎么比大小?比长度?还是比什么?其实不然,是依次比较的两个字符串中每个字符的ASCII码值,例如: “a” 和“b”,字符a的ASCII码值是97,字符b的ASCII码值是98,所以“a” < "b"的。
标准规定如下:
-
第一个字符串大于第二个字符串,则返回大于0的数字。
-
第一个字符串小于第二个字符串,则返回小于0的数字。
-
如果两个字符串相等,则返回数字0。
代码如下;
#include <stdio.h>
#include <string.h>
int main()
{
char s1[15] = “hello world”;
char s2[15] = “hello world”;
char s3[15] = “hello”;
int x1 = strcmp(s1, s2);
int x2 = strcmp(s1, s3);
printf(“s1与s2: %d\n”, x1); //相等
printf(“s1与s3: %d\n”, x2); //大于
return 0;
}
运行代码如下:
特别注意的是: strcmp函数比较的不是长度,而是从左到右依次比较每个字符的ASCII码值,例如下面代码,运行结果是多少?
#include <string.h>
#include <stdio.h>
int main()
{
char s1[10] = “abcde”;
char s2[20] = “abcdf”;
int x = strcmp(s1,s2);
printf(“%d\n”,x);
return 0;
}
5、strncmp
#include <string.h>
int strncmp( const char *string1, const char *string2, size_t count );
注释: strncmp函数,跟strcmp函数差不多啊,换汤不换药的,只是在原函数的基础之上 进行了改善,多了一个count参数,也就是需要比较count个字符。
代码如下:
#include <stdio.h>
#include <string.h>
int main()
{
char s1[10] = “abcdef”;
char s2[10] = “abcdfg”;
int x1 = strncmp(s1, s2, 4); //比较前4个字符
int x2 = strncmp(s1, s2, 6); //比较前6个字符
printf(“比较前4个字符: %d\n”, x1);
printf(“比较前6个字符: %d\n”, x2);
return 0;
}
运行结果如下:
6、strcat
#include <string.h>
char *strcat( char *Destination, const char *Source );
注释: strcat函数将source指向的数据 追加 到destination指向的内存空间的后面,例如:destination 指向的字符串是“C语言 “,source指针的字符串是”万岁“,追加之后的destination的内容就是”C语言万岁“。
值得注意的是;
-
source字符串必须以**’\0’** 结束。
-
destination指向的空间必须足够大。
-
destination必须是可修改的。
#include <stdio.h>
#include <string.h>
int main()
{
char dest[20] = "C语言 ";
char src[10] = “万岁”;
printf(“追加之前: %s\n”, dest);
strcat(dest, src);
printf(“追加之后: %s\n”, dest);
return 0;
}
运行代码如下:
7、strncat
#include <string.h>
char *strncat( char *strDest, const char *strSource, size_t count );
注释: strncat函数,也是在strcat函数的基础之上进行了完善,加入了参数count,追加count个字符。代码如下:
#include <stdio.h>
#include <string.h>
int main()
{
char dest[20] = “我会信你吗?”;
char src[20] = “我信你个鬼”;
printf(“追加之前: %s\n”, dest);
strncat(dest, src, 4); //为什么是4
printf(“追加之后: %s\n”, dest);
return 0;
}
运行代码如下:
这里提醒一下,拷贝的为什么是4个字节??
因为一个汉字占2个字节哦。
8、strtok
#include ,string.h>
char *strtok( char *strToken, const char *strDelimit );
注释: strtok函数,用于分隔字符串的,例如:“hello&world”,如果strDelimit的字符串是“&”,则strtok函数,会以&为分界线,将hello分隔成一个字符串,将world分隔成一个字符串。
值得注意的是;
-
strDelimit参数是个字符串,定义了用作分隔符的字符集合。
-
第一个参数指定一个字符串,它包含了0个或者多个由sep字符串中一个或者多个分隔符分割的标记。
-
strtok函数找到str中的下一个标记,并将其用 \0 结尾,返回一个指向这个标记的指针。(注:strtok函数会改
变被操作的字符串,所以在使用strtok函数切分的字符串一般都是临时拷贝的内容并且可修改。)
-
strtok函数的第一个参数不为 NULL ,函数将找到str中第一个标记,strtok函数将保存它在字符串中的位置。
-
strtok函数的第一个参数为 NULL ,函数将在同一个字符串中被保存的位置开始,查找下一个标记。
-
如果字符串中不存在更多的标记,则返回 NULL 指针。
#include <stdio.h>
#include <string.h>
int main()
{
char strToken[20] = “http:www.baidu.com”;
char strDelimit[10] = “/:.”;
printf(“分隔之前: %s\n”,strToken);
char* tmp = strtok(strToken, strDelimit);
printf(“分隔得到的字符串: %s\n”, tmp);
printf(“分隔之后: %s\n”, strToken);
return 0;
}
运行代码如下:
看上面的图,我们发现,分隔之后,原来的字符串被破坏了,所以在使用strtok函数的时候,都是先拷贝一份临时,去操作这个临时的字符串,才不会对原来的字符串带来破坏。
但其实,strtok函数,一般不是这样使用的,如下使用:
#include <stdio.h>
#include <string.h>
int main()
{
char strToken[20] = “http:www.baidu.com”; //本来还有 //的,因为考虑到转义字符,这里我就省略了
char string[20] = { 0 };
char* tmp = NULL;
char strDelimit[10] = “/:.”;
strcpy(string, strToken); //先拷贝一份临时的
//第一次使用strtok函数,第一个参数需要传入被分隔的字符串,第二次调用时,直接给NULL也可以,因为函数会自动保存上次分隔之后的下一个字符串的位置
for (tmp = strtok(string, strDelimit); tmp != NULL; tmp = strtok(NULL, strDelimit))
printf(“分隔得到的字符串: %s\n”, tmp);
return 0;
}
小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
读者福利
更多笔记分享
elimit))
printf(“分隔得到的字符串: %s\n”, tmp);
return 0;
}
小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Java工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Java开发全套学习资料》送给大家,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
[外链图片转存中…(img-eEu2bvHy-1710396623164)]
[外链图片转存中…(img-JAYZ9jT1-1710396623164)]
[外链图片转存中…(img-yEbiovIu-1710396623164)]
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频
如果你觉得这些内容对你有帮助,可以添加下面V无偿领取!(备注Java)
[外链图片转存中…(img-KT6oLlx2-1710396623165)]
读者福利
[外链图片转存中…(img-81wb2VH9-1710396623165)]
更多笔记分享
[外链图片转存中…(img-6da2n4w4-1710396623166)]