【C++】C++中的find方法介绍

目录

一.find方法基本用法

1.查找字符

2.查找子字符串

3.查找子字符串(从指定位置开始)

4.查找字符范围

5.查找不包含特定字符的范围

二.使用string::npos返回无效位置

三.总结


在C++中, std::string 类的 find 成员函数用于查找子字符串在字符串中的位置。 find 函数有多个重载版本,允许你以不同的方式执行查找操作。

一.find方法基本用法

cpp 复制代码
#include <iostream>
#include <string>

int main() {
    std::string str = "Hello World!";
    size_t pos = str.find("World");
    if (pos != std::string::npos) {
        std::cout << "Found 'World' at position: " << pos << std::endl;
    } else {
        std::cout << "The substring 'World' was not found." << std::endl;
    }
    return 0;
}

在这个示例中, find 被用来查找子字符串 "World" 在字符串 str 中的位置。如果找到了, pos 将包含子字符串的起始索引;如果没有找到, pos 将被设置为 std::string::npos 。

1.查找字符

cpp 复制代码
size_t pos = str.find('o');

这个调用查找字符 'o' 在字符串中的位置。

2.查找子字符串

cpp 复制代码
size_t pos = str.find("World");

这个调用查找子字符串 "World" 在字符串中的位置。

3.查找子字符串(从指定位置开始)

cpp 复制代码
size_t pos = str.find("World", 6);

这个调用从索引 6 开始查找子字符串 "World" 。

4.查找字符范围

cpp 复制代码
size_t pos = str.find_first_of("lo");

这个调用查找任何 "lo" 中的字符在字符串中第一次出现的位置。还有 find_last_of 来查找最后一次出现的位置。

5.查找不包含特定字符的范围

cpp 复制代码
size_t pos = str.find_first_not_of("Hdle");

这个调用查找第一个不是 "Hdle" 中的字符的位置。 find_last_not_of 用于查找最后一次出现的位置。

二.使用string::npos返回无效位置

string::npos 是 C++ 标准库中 std::string 类型的一个静态成员常量,表示"未找到"或"无效位置"。当你使用 std::string 的某些方法,如 find 、 rfind 、 find_first_of 等,它们返回一个位置索引时,如果没有找到指定的子字符串或字符,这些方法就会返回 string::npos 。

例如:

cpp 复制代码
std::string str = "Hello, World!";
size_t pos = str.find("test");

if (pos == std::string::npos) {
    // 没有找到子字符串 "test"
}

在这个例子中,如果 str 中没有 "test" 这个子字符串, pos 将被赋值为 string::npos 。

它的值是 std::string 类型能够表示的最大大小加一(通常是 size_t(-1) )。

三.总结

find 函数是 std::string 类中非常有用的成员函数之一,它提供了灵活的方式来查找子字符串或字符。使用 npos 可以检查查找操作是否成功。

相关推荐
香菇滑稽之谈13 分钟前
责任链模式的C++实现示例
开发语言·c++·设计模式·责任链模式
蜕变的土豆19 分钟前
二、重学C++—C语言核心
c语言·c++
夏天的阳光吖2 小时前
C++蓝桥杯基础篇(十一)
开发语言·c++·蓝桥杯
Alaso_shuang2 小时前
C++多态
c++
郭涤生2 小时前
并发操作的同步_第四章_《C++并发编程实战》笔记
开发语言·c++·算法
梦醒沉醉2 小时前
C++和标准库速成(一)——HelloWorld和名称空间
开发语言·c++
BIT_Legend2 小时前
Torch 模型 model => .onnx => .trt 及利用 TensorTR 在 C++ 下的模型部署教程
c++·人工智能·python·深度学习
.ccl3 小时前
蓝桥杯省赛真题C++B组2024-握手问题
c++·算法·蓝桥杯
神里流~霜灭4 小时前
下降路径最⼩和(medium)
数据结构·c++·算法·链表·贪心算法·动态规划
tan180°4 小时前
版本控制器Git(1)
c++·git·后端