学习字符串处理函数时,了解它们的名称来源、参数、实现原理以及潜在的问题非常有帮助。下面是一些函数的介绍:
a) 取字符串长度函数 strlen
:
-
名称来源:
strlen
是 “string length” 的缩写。 -
参数:接受一个指向以 null 结尾的字符串 (
char*
) 的指针作为参数。 -
实现原理:
strlen
函数通过遍历字符串中的字符,直到找到 null 结尾符 ('\0'
) 来计算字符串的长度。它返回的是size_t
类型,即无符号整数,表示字符串的长度。 -
示例代码:
#include <stdio.h> #include <string.h> int main() { const char *str = "Hello, World!"; size_t length = strlen(str); printf("字符串长度:%zu\n", length); return 0; }
-
输出结果:
字符串长度:13
-
注意事项:
strlen
不会检查越界,因此如果输入的字符串没有 null 结尾符,它可能会导致访问未定义的内存。
b) 字符串拷贝函数 strcpy
:
-
名称来源:
strcpy
是 “string copy” 的缩写。 -
参数:接受一个目标字符串 (
char*
) 和一个源字符串 (const char*
) 作为参数,将源字符串的内容复制到目标字符串中。 -
实现原理:
strcpy
会从源字符串的开头开始逐个复制字符到目标字符串,直到遇到 null 结尾符 ('\0'
)。然后,它在目标字符串的末尾添加 null 结尾符,以确保目标字符串是一个有效的 C 字符串。 -
示例代码:
#include <stdio.h> #include <string.h> int main() { char destination[20]; const char *source = "Hello"; strcpy(destination, source); printf("目标字符串:%s\n", destination); return 0; }
-
输出结果:
目标字符串:Hello
-
注意事项:使用
strcpy
时,确保目标字符串足够大,以容纳源字符串的内容和结尾符。否则可能会发生缓冲区溢出。
c) 字符串连接函数 strcat
:
-
名称来源:
strcat
是 “string concatenate” 的缩写。 -
参数:接受一个目标字符串 (
char*
) 和一个源字符串 (const char*
) 作为参数,将源字符串连接到目标字符串的末尾。 -
实现原理:
strcat
会定位目标字符串的结尾,然后从源字符串的开头开始逐个复制字符到目标字符串的结尾,直到遇到 null 结尾符 ('\0'
)。最后,它会在连接后的字符串末尾添加 null 结尾符,以确保目标字符串仍然是有效的 C 字符串。 -
示例代码:
#include <stdio.h> #include <string.h> int main() { char str1[20] = "Hello"; const char *str2 = " World"; strcat(str1, str2); printf("连接后的字符串:%s\n", str1); return 0; }
-
输出结果:
连接后的字符串:Hello World
-
注意事项:与
strcpy
一样,使用strcat
时,确保目标字符串足够大,以容纳源字符串的内容和结尾符。否则可能会发生缓冲区溢出。
d) 字符串比较函数 strcmp
:
-
名称来源:
strcmp
是 “string compare” 的缩写。 -
参数:接受两个源字符串 (
const char*
) 作为参数,用于比较这两个字符串。 -
实现原理:
strcmp
比较两个字符串的内容,按照字典顺序进行比较。它返回一个整数,表示比较的结果。如果字符串相等,返回0;如果第一个字符串小于第二个字符串,返回负数;如果第一个字符串大于第二个字符串,返回正数。 -
示例代码:
#include <stdio.h> #include <string.h> int main() { const char *str1 = "apple"; const char *str2 = "banana"; int result = strcmp(str1, str2); if (result < 0) { printf("%s 小于 %s\n", str1, str2); } else if (result > 0) { printf("%s 大于 %s\n", str1, str2); } else { printf("%s 等于 %s\n", str1, str2); } return 0; }
-
输出结果:
apple 小于 banana
-
注意事项:在使用
strcmp
比较字符串之前,确保字符串都以 null 结尾。不要将未以 null 结尾的字符串传递给strcmp
,因为它会导致未定义的行为。
e) 单字符查找函数 strchr
:
-
名称来源:
strchr
是 “string character” 的缩写。 -
参数:接受一个源字符串 (
const char*
) 和一个字符 (int c
) 作为参数,用于在字符串中查找指定的字符。 -
实现原理:
strchr
从源字符串的开头开始搜索指定字符,一旦找到字符,它返回该字符的指针。如果未找到字符,则返回NULL
。 -
代码示例:
#include <stdio.h>
#include <string.h>
int main() {
char str[] = "This is a sample string";
char* pch;
printf("在 \"%s\"中查找字符's'\n", str);
pch = strchr(str, 's');
while (pch != NULL) {
printf("在 %d 处找到\n", pch - str + 1);
pch = strchr(pch + 1, 's');
}
return 0;
}
- 输出结果:
找到字符 'W',位置:7
- 注意事项:请注意,
strchr
会在找到字符后立即返回,因此如果字符串中有多个相同的字符,它只会找到第一个。
f) 多字符查找函数 strpbrk
:
-
名称来源:
strpbrk
是 “string pointer break” 的缩写。 -
参数:接受一个源字符串 (
const char*
) 和一个字符集合字符串 (const char*
) 作为参数,用于在字符串中查找字符集合中的任何字符。 -
实现原理:
strpbrk
从源字符串的开头开始搜索,一旦找到源字符串中包含字符集合中的任何字符,它返回该字符的指针。如果未找到任何匹配字符,则返回NULL
。 -
代码示例:
#include <stdio.h>
#include <string.h>
int main() {
const char *str = "Hello, World!";
const char *charSet = "aeiou";
const char *result = strpbrk(str, charSet);
if (result != NULL) {
printf("找到字符集合中的字符 '%c',位置:%ld\n", *result, result - str);
} else {
printf("未找到字符集合中的字符\n");
}
return 0;
}
- 输出结果:
找到字符集合中的字符 'e',位置:1
- 注意事项:
strpbrk
会返回源字符串中字符集合中的第一个匹配字符。如果需要找到所有匹配字符,您可能需要编写循环来多次调用该函数。
g) 字符串分割函数 strtok
:
-
名称来源:
strtok
是 “string token” 的缩写。 -
参数:接受一个源字符串 (
char*
) 和一个分隔符字符串 (const char*
) 作为参数,用于将源字符串拆分成多个标记。 -
实现原理:
strtok
会根据分隔符字符串将源字符串分割成多个标记。它首次调用时返回第一个标记,后续调用返回后续标记。当没有更多标记时,返回NULL
。 -
代码示例:
#include <stdio.h>
#include <string.h>
int main() {
char str[] = "apple,banana,cherry";
const char *delimiters = ",";
char *token = strtok(str, delimiters);
while (token != NULL) {
printf("标记:%s\n", token);
token = strtok(NULL, delimiters);
}
return 0;
}
- 输出结果:
标记:apple
标记:banana
标记:cherry
- 注意事项:
strtok
在调用时会修改源字符串,将分隔符替换为 null 结尾符。因此,如果需要保留源字符串的原始内容,请先创建副本。
h) 字符串查找函数 strstr
:
-
名称来源:
strstr
是 “string strstr” 的缩写。 -
参数:接受一个源字符串 (
const char*
) 和一个要搜索的子字符串 (const char*
) 作为参数,用于在源字符串中查找子字符串的第一次出现。 -
实现原理:
strstr
在源字符串中搜索子字符串的第一次出现,一旦找到匹配,它返回子字符串的指针。如果未找到子字符串,返回NULL
。 -
代码示例:
#include <stdio.h>
#include <string.h>
int main() {
const char *str = "Hello, World!";
const char *searchStr = "World";
char *result = strstr(str, searchStr);
if (result != NULL) {
printf("找到子字符串 '%s',位置:%ld\n", searchStr, result - str);
} else {
printf("未找到子字符串 '%s'\n", searchStr);
}
return 0;
}
- 输出结果:
找到子字符串 'World',位置:7
- 注意事项:
strstr
只返回第一次出现的匹配。如果需要找到所有匹配,您可能需要编写循环来多次调用该函数。
务必注意,在使用这些函数时,保持字符串的完整性,防止越界和内存错误。