std::basic_string<CharT,Traits,Allocator>:: replace_with_range
| Classes | ||||
|
(C++17)
|
||||
|
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
template
<
container-compatible-range
<
CharT
>
R
>
constexpr
std::
basic_string
&
replace_with_range
(
const_iterator first,
|
(C++23 起) | |
将范围
[
first
,
last
)
中的字符替换为范围
rg
中的字符。
等同于
return replace(first, last, std::basic_string( std::from_range, std::forward<R>(rg), get_allocator()) );
目录 |
参数
| first, last | - | 将被替换的字符范围 |
| rg | - | 一个 容器兼容范围 |
返回值
* this
复杂度
线性于 rg 的大小。
异常
如果该操作将导致
size()
超过
max_size()
,则抛出
std::length_error
。
若因任何原因抛出异常,此函数不产生任何效果( 强异常安全保证 )。
注释
| 功能测试 宏 | 值 | 标准 | 功能 |
|---|---|---|---|
__cpp_lib_containers_ranges
|
202202L
|
(C++23) | 接受 容器兼容范围 的成员函数 |
示例
#include <algorithm> #include <cassert> #include <forward_list> #include <iterator> #include <string> int main() { using namespace std::literals; auto s{"Today is today!"s}; constexpr auto today{"today"sv}; constexpr auto tomorrow{"tomorrow's yesterday"sv}; std::forward_list<char> rg; std::ranges::reverse_copy(tomorrow, std::front_inserter(rg)); const auto pos{s.rfind(today)}; assert(pos != s.npos); const auto first{std::next(s.begin(), pos)}; const auto last{std::next(first, today.length())}; #ifdef __cpp_lib_containers_ranges s.replace_range(first, last, rg); #else s.replace(first, last, rg.cbegin(), rg.cend()); #endif assert("Today is tomorrow's yesterday!" == s); }
参见
|
替换字符串的指定部分
(公开成员函数) |