Chuyển tới nội dung chính

std::string::find

#include <string>

// (1) Tìm kiếm chuỗi con
size_type find( const basic_string& str, size_type pos = 0 ) const noexcept;

// (2) Tìm kiếm chuỗi ký tự C-style
size_type find( const charT* s, size_type pos = 0 ) const;

// (3) Tìm kiếm n ký tự đầu của chuỗi ký tự C-style
size_type find( const charT* s, size_type pos, size_type n ) const;

// (4) Tìm kiếm ký tự
size_type find( charT c, size_type pos = 0 ) const noexcept;

Tìm kiếm sự xuất hiện đầu tiên của một chuỗi con (substring), một ký tự, hoặc một chuỗi ký tự C-style bên trong một chuỗi std::string.

Tham số

str

  • Chuỗi std::string cần tìm kiếm (phiên bản 1).

s

  • Con trỏ đến chuỗi ký tự C-style (kết thúc bằng ký tự null) cần tìm kiếm (phiên bản 2, 3).

c

  • Ký tự cần tìm kiếm (phiên bản 4).

pos

  • Vị trí (index) bắt đầu tìm kiếm trong chuỗi hiện tại. Giá trị mặc định là 0 (tìm kiếm từ đầu chuỗi).

n

  • Số lượng ký tự đầu tiên của chuỗi ký tự C-style s cần tìm kiếm (phiên bản 3).

Giá trị trả về

size_type

  • Nếu tìm thấy, trả về vị trí (index) của sự xuất hiện đầu tiên của chuỗi con, ký tự, hoặc chuỗi C-style trong chuỗi hiện tại.
  • Nếu không tìm thấy, trả về giá trị đặc biệt std::string::npos (thường là -1, nhưng bạn nên sử dụng std::string::npos để so sánh thay vì -1).

Đặc điểm

  1. find() tìm kiếm sự xuất hiện đầu tiên của chuỗi con hoặc ký tự. Để tìm kiếm sự xuất hiện cuối cùng, hãy sử dụng rfind().
  2. find() phân biệt chữ hoa chữ thường (case-sensitive).
  3. Nếu pos vượt quá kích thước của chuỗi, find() sẽ trả về std::string::npos.
  4. Giá trị trả về của find() là kiểu size_type, thường là std::size_t. Đây là kiểu số nguyên không dấu.
  5. find() thường được sử dụng để:
    • Kiểm tra xem một chuỗi con có tồn tại trong chuỗi lớn hay không.
    • Xác định vị trí của một chuỗi con hoặc ký tự trong chuỗi.
    • Trích xuất một phần của chuỗi dựa trên vị trí tìm thấy.
    • Thực hiện các thao tác xử lý chuỗi dựa trên kết quả tìm kiếm.
Phân biệt với rfind(), find_first_of(), find_last_of(), find_first_not_of(), find_last_not_of(), và contains()
  • rfind(): Tìm kiếm sự xuất hiện cuối cùng của chuỗi con hoặc ký tự.
  • find_first_of(): Tìm kiếm sự xuất hiện đầu tiên của bất kỳ ký tự nào trong một tập hợp ký tự.
  • find_last_of(): Tìm kiếm sự xuất hiện cuối cùng của bất kỳ ký tự nào trong một tập hợp ký tự.
  • find_first_not_of(): Tìm kiếm sự xuất hiện đầu tiên của bất kỳ ký tự nào không trong một tập hợp ký tự.
  • find_last_not_of(): Tìm kiếm sự xuất hiện cuối cùng của bất kỳ ký tự nào không trong một tập hợp ký tự.
  • contains() (từ C++23): Kiểm tra xem chuỗi có chứa chuỗi con hoặc ký tự hay không (trả về bool).
  • find() Tìm kiếm sự xuất hiện đầu tiên và đầy đủ của chuỗi con hoặc ký tự.

Ví dụ

#include <iostream>
#include <string>

int main() {
std::string str = "Hello, world! This is a test string.";

// (1) Tìm kiếm chuỗi con
size_t pos1 = str.find("world");
if (pos1 != std::string::npos) {
std::cout << "Found \"world\" at position: " << pos1 << std::endl;
} else {
std::cout << "\"world\" not found.\n";
}

// (2) Tìm kiếm chuỗi ký tự C-style
size_t pos2 = str.find("This");
if (pos2 != std::string::npos) {
std::cout << "Found \"This\" at position: " << pos2 << std::endl;
}

// (3) Tìm kiếm n ký tự đầu của chuỗi ký tự C-style
const char* cstr = "testing";
size_t pos3 = str.find(cstr, 0, 4); // Tìm "test"
if (pos3 != std::string::npos) {
std::cout << "Found \"test\" at position: " << pos3 << std::endl;
}

// (4) Tìm kiếm ký tự
size_t pos4 = str.find('!');
if (pos4 != std::string::npos) {
std::cout << "Found '!' at position: " << pos4 << std::endl;
}

// Tìm kiếm từ vị trí khác 0
size_t pos5 = str.find("is", 5); // Tìm "is" bắt đầu từ vị trí 5
if (pos5 != std::string::npos) {
std::cout << "Found \"is\" starting from position 5 at: " << pos5 << std::endl;
}

return 0;
}

Các hàm liên quan

rfindTìm kiếm sự xuất hiện cuối cùng của một chuỗi con, một ký tự, hoặc một chuỗi ký tự C-style bên trong một chuỗi std::string
find_first_ofTìm kiếm sự xuất hiện đầu tiên trong chuỗi hiện tại của bất kỳ ký tự nào thuộc về một tập hợp các ký tự được chỉ định
find_last_ofTìm kiếm sự xuất hiện cuối cùng trong chuỗi hiện tại của bất kỳ ký tự nào thuộc về một tập hợp các ký tự được chỉ định
find_first_not_ofTìm kiếm sự xuất hiện đầu tiên trong chuỗi hiện tại của bất kỳ ký tự nào không thuộc về một tập hợp các ký tự được chỉ định
find_last_not_ofTìm kiếm sự xuất hiện cuối cùng trong chuỗi hiện tại của bất kỳ ký tự nào không thuộc về một tập hợp các ký tự được chỉ định
replaceThay thế một phần của chuỗi bằng một nội dung mới
substrTrích xuất một chuỗi con từ một chuỗi std::string hiện có