strstr函数使用例子
时间: 2024-10-24 22:00:34 浏览: 59
`strstr()` 函数是 C 标准库中的字符串处理函数,它用于在一个字符串(也称为"haystack")中查找另一个字符串("needle")第一次出现的位置。如果找到匹配,它会返回指向该子串开始位置的指针;如果没有找到,就返回 `NULL`。
一个简单的使用例子如下:
```c
#include <string.h>
char str[] = "Hello, World!";
const char* substr = "World";
// 使用 strstr 查找子串
size_t pos = strstr(str, substr) - str; // 注意减去 str 的地址获取实际偏移
if (pos != NULL) {
printf("Substring found at position %ld\n", (long)pos); // 输出子串的位置
} else {
printf("Substring not found.\n");
}
```
在这个例子中,`strstr(str, substr)` 返回的是 "World" 在 "Hello, World!" 中首次出现的位置,即从数组 str 开始算起的第 7 个字符处。如果找不到子串,则返回 `NULL`,因此判断条件检查了这个结果。
相关问题
C语言 strstr函数使用例子
下面是一个使用 C 语言中的 `strstr` 函数的示例:
```c
#include <stdio.h>
#include <string.h>
int main()
{
char str1[] = "Hello, World!";
char str2[] = "World";
char *result;
result = strstr(str1, str2);
if (result == NULL)
{
printf("'%s' is not found in '%s'\n", str2, str1);
}
else
{
printf("'%s' is found in '%s' at position %ld\n", str2, str1, result - str1);
}
return 0;
}
```
在此示例中,我们首先定义了两个字符串 `str1` 和 `str2`,并声明了一个指针变量 `result`。然后,我们使用 `strstr` 函数在 `str1` 中查找 `str2`。如果 `str2` 在 `str1` 中找到了,`strstr` 函数将返回指向 `str2` 在 `str1` 中第一次出现的位置的指针;否则,它将返回 `NULL`。
在这个示例中,我们使用 `if` 语句来检查 `result` 是否为 `NULL`。如果是,我们打印一条消息,指出 `str2` 在 `str1` 中未找到;否则,我们打印一条消息,指出 `str2` 在 `str1` 中的位置。
输出应该如下所示:
```
'World' is found in 'Hello, World!' at position 7
```
strstr函数使用方法
strstr函数是C语言中的一个字符串处理函数,其作用是在一个字符串中查找另一个字符串第一次出现的位置。其函数原型为:
```
char *strstr(const char *str1, const char *str2);
```
其中,str1表示要被查找的字符串,str2表示要查找的子字符串。函数返回值为一个指向str2在str1中第一次出现位置的指针,如果str2未在str1中出现,则返回NULL。
使用该函数时,需要注意以下几点:
1. 在使用该函数前,需要确保str1和str2指向的字符串以'\0'结尾,否则可能会导致结果不正确。
2. 在使用该函数时,应该判断函数的返回值是否为NULL,以确保查找到了需要的子字符串。
下面是一个使用strstr函数的例子:
```
#include <stdio.h>
#include <string.h>
int main()
{
char str1[] = "hello world";
char str2[] = "world";
char *p = NULL;
p = strstr(str1, str2);
if (p != NULL)
{
printf("'%s' is found in '%s' at position %ld.\n", str2, str1, p - str1);
}
else
{
printf("'%s' is not found in '%s'.\n", str2, str1);
}
return 0;
}
```
运行结果为:"'world' is found in 'hello world' at position 6."
阅读全文