#include
int main(){
int a = 10;
int b =5;
int c = 6;
int d = (a = 2+3,b = a-4,c= b+2);
printf("%d",d);
}
打印结果为:
逗号表达式,从左往右依次进行,将最后一个表达式的值赋值给变量.
求字符串长度 | strlen |
---|---|
长度不受限制的字符串函数 | strcpy , strcat , strcmp |
长度受限制的字符串函数 | strncpy , strncat , strncmp |
字符串查找 | strstr , strtok |
错误信息报告 | strerror |
内存操作函数 | memcpy , memmove , memset , memcmp |
下面分别进行详细介绍
所需头文件
#include
参数类型
size_t strlen(const char* string);
参数类型为char*,因此我们传进来的参数需要是字符串的地址,并且这里的指针变量用const修饰,可以保证传进来的字符串不被修改. 因为我们求字符串的长度是不需要对字符串进行修改的,加上const保证程序的安全. size_t是函数的返回值类型,他是一个无符号整型. 关于这个无符号整形,会导致一些问题,可以用一个例子说明.
#include
#include
int main()
{
char* str1 = "abc";
char* str2 = "abcedf";
if (strlen(str1) - strlen(str2) > 0)
{
printf("str1 is bigger\n");
}
else
{
printf("str2 is bigger\n");
}
return 0;
}
我们可以看出,str1比str2短,因此结果应该为负数,小于0,打印str2 is bigger
. 但是运行程序,发现结果如下:
这和我们所认为的不同,就是因为strlen函数返回的是一个无符号整型,因此当两个无符号整型进行减法的时候,得到的结果仍然是无符号整型,因此虽然得到的结果为负数,但是在无符号整型看来,这是一个很大的正数,前面的符号位被认为是一个有效的数字位,导致结果大于0.打印的是str1 is bigger
. 如果想要进行比较长度大小,可以直接strlen(str1) > strlen(str2)
这样子比较就没有问题了.
注意事项
- strlen函数返回的是在字符串中
\0
前面出现的字符个数(不包含 ‘\0’ ),因此当字符串中存在\0
的时候,得到的不是字符串的长度- 参数指向的字符串必须要以 ‘\0’ 结束,否则strlen会运行到读取到
\0
才结束- 注意函数的返回值为size_t,是无符号的,在计算的时候要注意
所需头文件
#include
参数类型
char *strcpy(char *strDestination,const char* strSource);
参数类型是两个字符串指针地址,第一个是需要被拷贝的字符串地址,第二个参数是要拷贝的内容. 其中要拷贝的内容由于不需要改变,用const修饰,保证程序的安全. 函数的返回值类型为char*类型,是拷贝完成后的字符串地址.
注意事项
- strSource必须以
\0
结束,否则strcpy函数不知道什么时候拷贝结束- 拷贝会将
\0
也拷贝到strDestination中- strDestination必须足够大,确保放的下strSource,防止越界访问
- strDestination不能被const修饰,必须是可变的.
所需头文件
#include
参数类型
char *strcat(char *strDestination,const char* strSource);
参数类型和strcpy是一致的,就不再赘述了. 返回值类型也是char*类型.用来返回被追加后的字符串地址.
具体功能是将两个字符串拼接起来.
#include
#include
int main()
{
char str1[20] = "abcd";
char str2[] = "efgh";
char* ret = strcat(str1, str2);
printf("%s", ret);
return 0;
}
运行结果如下:
strcat的注意事项和strcpy类似,唯一的区别在于strDestination的空间要足够大,能够放得下strSource+原strDestination才行.而strcpy只需要能够放得下strSource就行.
所需头文件
#include
参数类型
int strcmp(const char *string1,const char* string2);
参数为两个字符串指针,都被const修饰,不需要对字符串进行修改,只是进行比较,保证程序的安全性. 返回值类型为int类型.
strcmp函数对返回值的规定如下:
strcmp函数的功能就是比较两个字符串的大小,比较的是字符串的内容而不是字符串的长度.
比方说abcde
就小于accd
因为从第二个字符开始,b的ASCII码小于c的ASCII码. 但字符串的长度确实abcde
大于accd
所需头文件
#include
参数类型
char *strncpy( char *strDestination,const char *strSource,size_t count);
前两个参数类型和strcpy是一致的,只是多了个size_t类型的参数count用来控制拷贝字符的个数. 这里的count为多少,就从strSource中拷贝多少个字符到strDestination中. 返回值类型也和strcpy一样,返回的是被拷贝的字符串的地址
strncpy的功能如下:
#include
#include
int main()
{
char str1[20] = "abcd";
char str2[] = "kpl";
char* ret = strncpy(str1, str2, 2);
printf("%s", ret);
return 0;
}
运行结果如下:
作用就是经str2的前面两个字符串拷贝到str1的前面两位.因此结果为kpcd
注意事项和strcpy是一致的.
所需头文件
#include
参数类型
char *strncat(char *strDestination,const char* strSource, size_t count);
和strncpy类似,也是多了个size_t类型的count用来控制追加字符串的长度.返回的也是被追加字符串的地址.
#include
#include
int main()
{
char str1[20] = "abcd";
char str2[] = "efgh";
char* ret = strncat(str1, str2, 2);
printf("%s", ret);
return 0;
}
运行结果为:
将str2中的前面两个字符追加到str1中,因此结果为abcdef
注意事项和strncat一致.
所需头文件
#include
参数类型
int strncmp(const char *string1,const char* string2, size_t count);
类似的,多了个size-t类型的count,用来控制比较字符串的长度. 返回的值和strcmp一样.
#include
#include
int main()
{
char str1[] = "abcd";
char str2[] = "abkl";
int ret = strncmp(str1, str2, 2);
printf("%d", ret);
return 0;
}
运行结果为:
由于str1和str2前面两个字符都为ab,因此比较的结果是两者相等,因此结果为0
如果使用strcmp比较,结果为小于0的数字.
所需头文件
#include
参数类型
char *strstr(const char *string,const char* strCharSet);
参数是两个指针,分别接收的是被查找的字符串地址和查找内容的字符串地址,两个指针都被const修饰. 返回值类型为char*,所以接收的是字符string被strcharset查找到后,对应查找到的字符串的首地址.
#include
#include
int main()
{
char str1[] = "abcdefdgh";
char str2[] = "d";
char* ret = strstr(str1, str2);
printf("%s", ret);
return 0;
}
运行结果为: