std::string find_last_of() 方法
- 自 C++20 起
- 自 C++17 起
- 自 C++11 起
- 直到 C++11
// (1) Const version only
constexpr size_type find_last_of( const basic_string& str, size_type pos = 0 ) const noexcept;
// (2) Const version only
constexpr size_type find_last_of( const CharT* s, size_type pos, size_type count ) const;
// (3) Const version only
constexpr size_type find_last_of( const CharT* s, size_type pos = 0 ) const;
// (4) Const version only
constexpr size_type find_last_of( CharT ch, size_type pos = 0 ) const noexcept;
// (5) Const version only
template < class StringViewLike >
constexpr size_type find_last_of( const StringViewLike& t, size_type pos = 0 ) const noexcept(/* see below */);
// (1) Const version only
size_type find_last_of( const basic_string& str, size_type pos = 0 ) const noexcept;
// (2) Const version only
size_type find_last_of( const CharT* s, size_type pos, size_type count ) const;
// (3) Const version only
size_type find_last_of( const CharT* s, size_type pos = 0 ) const;
// (4) Const version only
size_type find_last_of( CharT ch, size_type pos = 0 ) const noexcept;
// (5) Const version only
template < class StringViewLike >
size_type find_last_of( const StringViewLike& t, size_type pos = 0 ) const noexcept(/* see below */);
// (1) Const version only
size_type find_last_of( const basic_string& str, size_type pos = 0 ) const noexcept;
// (2) Const version only
size_type find_last_of( const CharT* s, size_type pos, size_type count ) const;
// (3) Const version only
size_type find_last_of( const CharT* s, size_type pos = 0 ) const;
// (4) Const version only
size_type find_last_of( CharT ch, size_type pos = 0 ) const noexcept;
// (1) Const version only
size_type find_last_of( const basic_string& str, size_type pos = 0 ) const;
// (2) Const version only
size_type find_last_of( const CharT* s, size_type pos, size_type count ) const;
// (3) Const version only
size_type find_last_of( const CharT* s, size_type pos = 0 ) const;
// (4) Const version only
size_type find_last_of( CharT ch, size_type pos = 0 ) const;
查找与给定字符序列中某个字符相同的最后一个字符。
搜索仅考虑区间 **[ 0, pos ]**。
-
(1) 查找与
str
中某个字符相同的最后一个字符。 -
(2) 查找与范围 [ s, s + count ) 中某个字符相同的最后一个字符。
此范围可以包含空字符。 -
(3) 查找与
s
指向的字符串中某个字符相同的最后一个字符。
字符串的长度由 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>>
为true
且std::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()
用于比较。默认情况下,`Traits` 是 std::char_traits<CharT>
。
示例
#include <string>
#include <iostream>
int main()
{
const std::string path = "/root/config";
auto const pos = path.find_last_of('/');
const auto leaf = path.substr(pos + 1);
std::cout << leaf << '\n';
}
config