transform_view.rst

来自「Boost provides free peer-reviewed portab」· RST 代码 · 共 101 行

RST
101
字号
.. Sequences/Views//transform_view.. Copyright Aleksey Gurtovoy, David Abrahams 2007... Distributed under the Boost.. Software License, Version 1.0. (See accompanying.. file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)transform_view==============Synopsis--------.. parsed-literal::        template<          typename Sequence        , typename F        >    struct transform_view    {        // |unspecified|        // |...|    };Description-----------A view the full range of ``Sequence``\ 's transformed elements.Header------.. parsed-literal::        #include <boost/mpl/transform_view.hpp>Model of--------* |Forward Sequence|Parameters----------+---------------+-------------------------------+-------------------------------+| Parameter     | Requirement                   | Description                   |+===============+===============================+===============================+| ``Sequence``  | |Forward Sequence|            | A sequence to wrap.           |+---------------+-------------------------------+-------------------------------+| ``F``         | Unary |Lambda Expression|     | A transformation.             |+---------------+-------------------------------+-------------------------------+Expression semantics--------------------|Semantics disclaimer...| |Forward Sequence|.In the following table, ``v`` is an instance of ``transform_view``, ``s`` is an arbitrary |Forward Sequence|, and ``f`` is an unary |Lambda Expression|.+-----------------------------------+-----------------------------------------------------------+| Expression                        | Semantics                                                 |+===================================+===========================================================+| .. parsed-literal::               | A lazy |Forward Sequence| such that for each ``i`` in the ||                                   | range |begin/end<v>| and each ``j`` in for in the range   ||    transform_view<s,f>            | |begin/end<s>| ``deref<i>::type`` is identical to         ||    transform_view<s,f>::type      | ``apply< f, deref<j>::type >::type``.                     |+-----------------------------------+-----------------------------------------------------------+| ``size<v>::type``                 | The size of ``v``;                                        ||                                   | ``size<v>::value == size<s>::value``;                     ||                                   | linear complexity; see |Forward Sequence|.                |+-----------------------------------+-----------------------------------------------------------+Example-------Find the largest type in a sequence... parsed-literal::        typedef vector<int,long,char,char[50],double> types;    typedef max_element<          transform_view< types, size_of<_> >        >::type iter;    BOOST_MPL_ASSERT_RELATION( deref<iter>::type::value, ==, 50 );See also--------|Sequences|, |Views|, |filter_view|, |joint_view|, |zip_view|, |iterator_range|

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?