命名空间
变体
操作

std::projected

来自 cppreference.com
< cpp‎ | iterator
 
 
迭代器库
迭代器概念
迭代器原语
算法概念和实用程序
间接可调用概念
常见算法要求
(C++20)
(C++20)
(C++20)
实用程序
projected
(C++20)
迭代器适配器
范围访问
(C++11)(C++14)
(C++14)(C++14)  
(C++11)(C++14)
(C++14)(C++14)  
(C++17)(C++20)
(C++17)
(C++17)
 
定义在头文件 <iterator>
(1)
template< std::indirectly_readable I,

          std::indirectly_regular_unary_invocable<I> Proj >
struct projected
{
    using value_type = std::remove_cvref_t<std::indirect_result_t<Proj&, I>>;
    std::indirect_result_t<Proj&, I> operator*() const; // 未定义

};
(自 C++20 起)
(直到 C++26)
template< std::indirectly_readable I,

          std::indirectly_regular_unary_invocable<I> Proj >

using projected = /*projected-impl*/<I, Proj>::/*__type*/; // 参见 (3)
(自 C++26 起)
template< std::weakly_incrementable I, class Proj >

struct incrementable_traits<std::projected<I, Proj>>
{
    using difference_type = std::iter_difference_t<I>;

};
(2) (自 C++20 起)
(直到 C++26)
template< class I, class Proj >

struct /*projected-impl*/
{
    struct /*__type*/
    {
        using value_type = std::remove_cvref_t<std::indirect_result_t<Proj&, I>>;
        using difference_type = std::iter_difference_t<I>; // 有条件地存在

        std::indirect_result_t<Proj&, I> operator*() const; // 未定义
    };

};
(3) (自 C++26 起)
(仅供说明*)
1) (直到 C++26)别名(自 C++26 起) 模板 projected 将一个 indirectly_readable 类型 I 和一个可调用对象类型 Proj 组合成一个新的 indirectly_readable 类型,其引用类型是将 Proj 应用于 std::iter_reference_t<I> 的结果。
2) std::incrementable_traits 的此特化使 std::projected<I, Proj>I 也是一个 weakly_incrementable 类型时成为一个 weakly_incrementable 类型。
3) 用于避免意外的 与参数相关的查找 的间接层。成员类型 difference_type 仅在 Iweakly_incrementable 建模时存在。

projected 仅用于约束接受可调用对象和投影的算法,因此其 operator*() 未定义。

内容

[编辑] 模板参数

I - 间接可读类型
Proj - 应用于解引用 I 的投影

[编辑] 说明

间接层可防止 IProj 成为 projected 的关联类。当 IProj 的关联类是未完成的类类型时,间接层会避免不必要的尝试检查该类型的定义,从而导致硬错误。

[编辑] 示例

#include <algorithm>
#include <cassert>
#include <functional>
#include <iterator>
 
template<class T>
struct Holder
{
    T t;
};
 
struct Incomplete;
 
using P = Holder<Incomplete>*;
 
static_assert(std::equality_comparable<P>); // OK
static_assert(std::indirectly_comparable<P*, P*, std::equal_to<>>); // Error before C++26
static_assert(std::sortable<P*>); // Error before C++26
 
int main()
{
    P a[10] = {}; // ten null pointers
    assert(std::count(a, a + 10, nullptr) == 10); // OK
    assert(std::ranges::count(a, a + 10, nullptr) == 10); // Error before C++26
}

[编辑] 另请参见

通过投影计算 indirectly_readable 类型的值类型
(别名模板)[编辑]