【std::string】find函数

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录


在C++的std::string中,find方法是用于在字符串中查找子串或字符的核心成员函数,其作用是定位目标内容在当前字符串中首次出现的位置。

一、核心功能

find方法会从字符串的指定位置(默认从起始位置,即索引0)开始,搜索目标子串(或字符),并返回其首次出现的起始索引;若未找到,则返回特殊值std::string::npos

二、函数原型(常用重载版本)

std::stringfind方法有多个重载版本,覆盖不同的查找需求,常用的有以下几种:

  1. 查找字符

    从指定位置pos开始,查找单个字符c

    cpp 复制代码
    size_t find(char c, size_t pos = 0) const;
  2. 查找std::string子串

    从指定位置pos开始,查找子串s

    cpp 复制代码
    size_t find(const std::string& s, size_t pos = 0) const;
  3. 查找C风格字符串(以\0结尾)

    从指定位置pos开始,查找C字符串s

    cpp 复制代码
    size_t find(const char* s, size_t pos = 0) const;
  4. 查找C风格字符串的前count个字符

    从指定位置pos开始,查找C字符串s的前count个字符:

    cpp 复制代码
    size_t find(const char* s, size_t pos, size_t count) const;

三、返回值说明

  • 若找到目标,返回目标内容在当前字符串中首次出现的起始索引(索引从0开始)。
  • 若未找到,返回std::string::npos(这是一个静态常量,通常等价于size_t(-1),用于表示"未找到")。

四、使用示例

以下示例基于字符串str = "hello world, hello cpp"演示find的用法:

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

int main() {
    std::string str = "hello world, hello cpp";

    // 1. 查找字符 'o'(默认从位置0开始)
    size_t pos1 = str.find('o');
    if (pos1 != std::string::npos) {
        std::cout << "字符 'o' 首次出现位置:" << pos1 << "\n"; // 输出:4("hello"的第4个索引)
    }

    // 2. 查找子串 "hello"(从位置0开始)
    size_t pos2 = str.find("hello");
    if (pos2 != std::string::npos) {
        std::cout << "子串 \"hello\" 首次出现位置:" << pos2 << "\n"; // 输出:0
    }

    // 3. 从位置6开始查找子串 "hello"(跳过第一个"hello")
    size_t pos3 = str.find("hello", 6);
    if (pos3 != std::string::npos) {
        std::cout << "从位置6开始,子串 \"hello\" 首次出现位置:" << pos3 << "\n"; // 输出:13
    }

    // 4. 查找不存在的子串 "java"
    size_t pos4 = str.find("java");
    if (pos4 == std::string::npos) {
        std::cout << "子串 \"java\" 未找到\n"; // 输出此句
    }

    return 0;
}

五、注意事项

  1. 索引范围pos参数需小于字符串长度(str.size()),否则可能返回npos(未定义行为,建议确保pos有效)。
  2. 区分大小写find是大小写敏感的,例如查找"Hello"和"hello"会被视为不同子串。
  3. 返回值类型 :返回值为size_t(无符号整数),若用int接收可能导致负数转换问题,建议直接用size_tauto
  4. npos的判断 :必须用== std::string::npos判断是否找到,不能用== -1(尽管值可能相同,但size_t是无符号类型,逻辑上不严谨)。

六、与其他查找方法的区别

std::string还提供了其他查找相关方法,可根据需求选择:

  • rfind:从字符串末尾反向查找(最后一次出现的位置)。
  • find_first_of:查找目标中任意字符首次出现的位置。
  • find_last_of:查找目标中任意字符最后一次出现的位置。

find是最基础的"正向全匹配"查找,是字符串搜索的首选方法。

相关推荐
在路上看风景2 小时前
19. 成员初始化列表和初始化对象
c++
zmzb01032 小时前
C++课后习题训练记录Day98
开发语言·c++
念风零壹2 小时前
C++ 内存避坑指南:如何用移动语义和智能指针解决“深拷贝”与“内存泄漏”
c++
孞㐑¥3 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法
MZ_ZXD0015 小时前
springboot旅游信息管理系统-计算机毕业设计源码21675
java·c++·vue.js·spring boot·python·django·php
A星空1236 小时前
一、Linux嵌入式的I2C驱动开发
linux·c++·驱动开发·i2c
凡人叶枫6 小时前
C++中智能指针详解(Linux实战版)| 彻底解决内存泄漏,新手也能吃透
java·linux·c语言·开发语言·c++·嵌入式开发
会叫的恐龙6 小时前
C++ 核心知识点汇总(第六日)(字符串)
c++·算法·字符串
小糯米6016 小时前
C++顺序表和vector
开发语言·c++·算法
独望漫天星辰6 小时前
C++ 多态深度解析:从语法规则到底层实现(附实战验证代码)
开发语言·c++