strlen
size_t strlen(const char* str);
strlen是一个用来求字符串长度的函数。字符串已经用'\0'作为结束标志,strlen函数返回的是在字符串中'\0'之前出现的字符个数,不包括'\0'。
注意:
1.用strlen求字符串长度时,参数指向的字符串必须要以'\0'结束,否则求出的值不是字符串的长度而是随机值。
2.size_t 指的是无符号整型,即strlen的返回值是无符号整型。
错误示例:
int main()
{
if (strlen("abc") - strlen("abcdef") > 0)
{
printf(">\n");
}
else
{
printf("<=\n");
}
return 0;
}
输出的结果不是<=而是>,原因就是 strlen的返回值是无符号整型。两个无符号整型运行的结果还是无符号整型,因此 3-6的结果-3的补码会被当做无符号整型计算,因此结果还是大于零。
strcpy
char* strcpy(char* destination, const char* source);
注意:
1.strcpy 拷贝完'\0'就结束了,并会将'\0'拷贝到目标空间,因此如果字符串不以'\0'结束就无法使用strcpy。
2.目标空间必须足够大,确保能存放源字符串。不然强行拷贝程序会崩溃。
3.目标空间必须可变。
strcat
char* strcat(char* destination, const char* source);
strcat用来追加字符串,当把'\0'也追加到字符串末尾时,追加结束。
注意的要点与strcpy类似,但要注意不要用strcat自己给自己追加。
strcmp
int strcmp(const char* strl, const char* str2);
比较两个字符串,不是比长度而是比内容,比如abq大于abcdef。
第一个字符串大于第二个字符串会返回一个大于零的数字,相等返回0,小于返回一个小于零的数字。
注意:strcpy、strcat、strcmp都是长度不受限制字符串函数。空间不够大时会造成越界访问是这类函数的安全隐患。而以下要介绍的strncpy、strncat、strncmp都是长度受限制的字符串函数。
strncpy
char* strncpy(char* destination, const char* source, size_t num);
strncpy比strcpy多了一个参数,用来决定要拷贝的字节数。
追加完指定字节数后strncpy还会在字符串后追加一个'\0'。
strncmp
char* strncmp(const char* str1,const char* str2,size_t num);
只比较字符串中指定个数的字符。
strstr
char* strstr(const char* str1, const char* str2);
strstr是一个用来查找子串的字符串。查找字符串1中是否包含字符串2, 返回值是子串在字符串中的起始位置,不包含子串返回NULL。
strtok
用来切割字符串。
char* strtok(char* str, const char* sep);
str是被切割的字符串,它包含了0个或多个由sep字符串中的一个或多个分隔符分割的标记。sep参数是一个字符串,定义了用作分隔符的字符合集。strtok函数找到str中的下一个标记,并将其用'\0'结尾,返回一个指向这个标记的指针。即strtok会改变字符串,所以最好创建一份拷贝再使用strtok。
注意:
1.当strtok函数的第一个参数不为NULL,函数将找到str中的第一个标记,strtok函数将保存它在字符串中的位置。
2.strtok函数的第一个参数为NULL,函数将在同一个字符串中被保存的位置开始,查找下一个标记。
3.如果字符串中不存在更多的标记,则返回NULL指针。
4.如果两个分隔符连在一起,和一个分隔符效果相同。
strtok有记忆功能,并且只有找第一个字段时传的不是空指针。
用法示例(简单):
int main()
{
const char* sep = "@.";
char email[] = "1234567@abcd.com";
char cp[30] = { 0 };
strcpy(cp, email);
char* ret = strtok(cp, sep);
printf("%s\n", ret);
ret = strtok(NULL, sep);
printf("%s\n", ret);
ret = strtok(NULL, sep);
printf("%s\n", ret);
strtok(email, sep);
return 0;
}
但以上代码只能在明确分隔符个数的情况下才能用,所以实用性不够。用一个for循环就能在不明确分隔符个数的情况下使用。
int main()
{
const char* sep = "@.";
char email[] = "1234567@abcd.com";
char cp[30] = { 0 };
strcpy(cp, email);
char* ret = NULL;
for (ret = strtok(cp, sep);
ret != NULL;
ret = strtok(NULL, sep))
{
printf("%s\n", ret);
}
return 0;
}
strerror
char* strerror (int errnum);
C语言的库函数,在执行失败的时候,都会设置错误码,strerror的功能就是返回错误码对应的错误信息。
例如:
int main()
{
printf("%s\n", strerror(0));
printf("%s\n", strerror(1));
printf("%s\n", strerror(2));
printf("%s\n", strerror(3));
printf("%s\n", strerror(4));
printf("%s\n", strerror(5));
return 0;
}
输出结果为
用法举例:
int main()
{
FILE* pf = fopen("test1.txt", "r");
if (pf == NULL)
{
printf("%s\n", strerror(errno));
return 1;
}
return 0;
}
如果打开一个不存在的文件,输出的错误信息为:
注意:
errno是C语言设置的一个全局的错误码存放的变量。使用时要引用头文件<errno.h>。
字符函数
另外除了字符串函数还有一些简单的字符分类函数。
函数 | 如果他的参数符合下列条件就返回真 |
iscntrl | 控制任何字符 |
isspace | 空白 |
isdigit | 十进制数字0~9 |
isxdigit | 十六进制数字,包括所有十进制数字,小写字母a~f,大写字母A~F |
islower | 小写字母a~z |
isupper | 大写字母A~Z |
isalpha | 字母a~z或A~Z |
isalnum | 字母或者数字,a~z,A~Z,0~9 |
ispunct | 标点符号,任何不属于数字或者字母的图形字符(可打印) |
isgraph | 任何图形字符 |
isprint | 任何可打印字符,包括图形字符和空白字符 |
注释:" ","\t","\n","\v","\f","\r"均为空白字符。
另外toupper和tolower是字符转换函数。