【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 可以检查查找操作是否成功。

相关推荐
Maple_land1 小时前
Linux进程第八讲——进程状态全景解析(二):从阻塞到消亡的完整生命周期
linux·运维·服务器·c++·centos
ajassi20001 小时前
开源 C++ QT QML 开发(十一)通讯--TCP服务器端
c++·qt·开源
lyp90h1 小时前
高效SQLite操作:基于C++模板元编程的自动化封装
c++
minji...2 小时前
Linux相关工具vim/gcc/g++/gdb/cgdb的使用详解
linux·运维·服务器·c++·git·自动化·vim
_OP_CHEN2 小时前
C++基础:(九)string类的使用与模拟实现
开发语言·c++·stl·string·string类·c++容器·stl模拟实现
爱编程的化学家2 小时前
代码随想录算法训练营第27天 -- 动态规划1 || 509.斐波那契数列 / 70.爬楼梯 / 746.使用最小花费爬楼梯
数据结构·c++·算法·leetcode·动态规划·代码随想录
数字化顾问3 小时前
C++分布式语音识别服务实践——架构设计与关键技术
c++
智能化咨询3 小时前
C++分布式语音识别服务实践——性能优化与实战部署
c++
ajassi20004 小时前
开源 C++ QT QML 开发(十四)进程用途
c++·qt·开源
闻缺陷则喜何志丹4 小时前
【C++贪心】P8769 [蓝桥杯 2021 国 C] 巧克力|普及+
c++·算法·蓝桥杯·洛谷