名稱空間
變體
操作

std::basic_string<CharT,Traits,Allocator>::find_first_of

來自 cppreference.com
< cpp‎ | string‎ | basic_string
 
 
 
std::basic_string
 
size_type find_first_of( const basic_string& str, size_type pos = 0 ) const;
(1) (C++11 起無異常丟擲)
(C++20 起為 constexpr)
size_type find_first_of( const CharT* s,
                         size_type pos, size_type count ) const;
(2) (C++20 起為 constexpr)
size_type find_first_of( const CharT* s, size_type pos = 0 ) const;
(3) (C++20 起為 constexpr)
size_type find_first_of( CharT ch, size_type pos = 0 ) const;
(4) (C++11 起無異常丟擲)
(C++20 起為 constexpr)
template< class StringViewLike >

size_type
    find_first_of( const StringViewLike& t,

                   size_type pos = 0 ) const noexcept(/* 參見下文 */);
(5) (C++17 起)
(C++20 起為 constexpr)

查詢等於給定字元序列中任一字元的第一個字元。搜尋僅考慮範圍 [possize())。如果給定字元序列中的所有字元都不在該範圍內,則返回 npos

1) 查詢等於 str 中任一字元的第一個字元。
2) 查詢等於範圍 [ss + count) 中任一字元的第一個字元。此範圍可以包含空字元。
如果 [ss + count) 不是有效範圍,則行為未定義。
3) 查詢等於由 s 指向的字元字串中任一字元的第一個字元。字串的長度由使用 Traits::length(s) 的第一個空字元確定。
如果 [ss + Traits::length(s)) 不是有效範圍,則行為未定義。
4) 查詢等於 ch 的第一個字元。
5)t 隱式轉換為字串檢視 sv,如同透過 std::basic_string_view<CharT, Traits> sv = t;,然後查詢等於 sv 中任一字元的第一個字元。
此過載僅在 std::is_convertible_v<const StringViewLike&,
                      std::basic_string_view<CharT, Traits>>
truestd::is_convertible_v<const StringViewLike&, const CharT*>false 時參與過載決議。

目錄

[編輯] 引數

str - 標識要搜尋的字元的字串
pos - 開始搜尋的位置
count - 標識要搜尋的字元的字串的長度
s - 指向標識要搜尋的字元的字元字串的指標
ch - 要搜尋的字元
t - 標識要搜尋的字元的物件(可轉換為 std::basic_string_view

[編輯] 返回值

找到的字元的位置,如果未找到此類字元則為 npos

[編輯] 異常

1,4) 不丟擲任何異常。
5)
noexcept 規範:  
noexcept(std::is_nothrow_convertible_v<const T&, std::basic_string_view<CharT, Traits>>)

如果由於任何原因丟擲異常,此函式無效果(強異常安全保證)。

[編輯] 注意

使用 Traits::eq() 執行比較。

[編輯] 示例

#include <cassert>
#include <iostream>
#include <string>
#include <string_view>
 
int main()
{
    using namespace std::literals;
    std::string::size_type sz;
 
    // (1)
    sz = "alignas"s.find_first_of("klmn"s);
    //     └────────────────────────┘
    assert(sz == 1);
 
    sz = "alignof"s.find_first_of("wxyz"s);
    // no match
    assert(sz == std::string::npos);
 
    // (2)
    sz = "consteval"s.find_first_of("xyzabc", 0, 3);
    // no match (× are not targets)     ×××
    assert(sz == std::string::npos);
 
    sz = "consteval"s.find_first_of("xyzabc", 0, 6);
    //    └───────────────────────────────┘
    assert(sz == 0);
 
    // (3)
    sz = "decltype"s.find_first_of("xyzabc");
    //      └────────────────────────────┘
    assert(sz == 2);
 
    // (4)
    sz = "co_await"s.find_first_of('a');
    //       └──────────────────────┘
    assert(sz == 3);
 
    // (5)
    sz = "constinit"s.find_first_of("int"sv);
    //      └─────────────────────────┘
    assert(sz == 2);
 
    std::cout << "All tests passed.\n";
}

輸出

All tests passed.

[編輯] 缺陷報告

下列更改行為的缺陷報告追溯地應用於以前出版的 C++ 標準。

缺陷報告 應用於 釋出時的行為 正確的行為
LWG 847 C++98 沒有異常安全保證 添加了強異常安全保證
LWG 2064 C++11 過載 (3,4) 為 noexcept 已移除
LWG 2946 C++17 過載 (5) 在某些情況下導致歧義 透過使其成為模板來避免
P1148R0 C++11
C++17
過載 (4,5) 的 noexcept 被
LWG2064/LWG2946 意外刪除
恢復

[編輯] 另請參閱

查詢給定子字串的第一次出現
(公共成員函式) [編輯]
查詢子串的最後一次出現
(公共成員函式) [編輯]
查詢字元的首次缺席
(公共成員函式) [編輯]
查詢字元的最後一次出現
(公共成員函式) [編輯]
查詢字元的最後一次缺席
(公共成員函式) [編輯]
查詢字元的首次出現
(std::basic_string_view<CharT,Traits> 的公共成員函式) [編輯]
返回由另一個位元組字串中找到的字元組成的最大初始段的長度
的字元
(函式) [編輯]