繁体   English   中英

在 C++ 模板中将类型传递给 Lambda 函数

[英]Passing Type Into Lambda Function In C++ Template

我正在尝试在模板函数中使用std::transform 因为模板函数需要处理的类型多种多样,所以关键部分是std::transform lambda 函数的设计。 我想传递可迭代T的基类型来构造一个 lambda 函数。 此处的实验代码使用typename std::iterator_traits<T::iterator>::value_type使用 gcc 10.2 和 MSVC 19.27 成功编译,但使用 clang 失败

我换了之后

typename std::iterator_traits<T::iterator>::value_type

进入

typename std::iterator_traits<typename T::iterator>::value_type

问题似乎解决了 但是,我不确定这是否是正确的用法。 此外,如果有任何其他更好的方法可以做到这一点,请告诉我。

template<typename T>
concept ElementSummable = requires(T x)
{
    x.at(0) + x.at(0);
};

template<typename T>
concept Iterable = requires(T x)
{
    x.begin();      // must have `x.begin()` 
    x.end();        // and `x.end()` 
};

template<class T> requires Iterable<T> && ElementSummable<T>
static T Foo(const T _input);

template<class T> requires Iterable<T> && ElementSummable<T>
static inline T Foo(const T _input)
{
    T returnObject = _input;
    std::transform(_input.begin(), _input.end(), returnObject.begin(),
        [](typename std::iterator_traits<T::iterator>::value_type element)->typename std::iterator_traits<T::iterator>::value_type
        {
            return element + 1;         //  For example
        }
    );
    return returnObject;
}

int main()
{
    long double number = 1;
    std::vector<decltype(number)> testVector1;
    testVector1.push_back(number);
    testVector1.push_back(number);

    std::cout << Foo(testVector1).at(0);
    return 0;
}

问题是CLang编译器相对于标准的刚性。

问题不在于类型(这是正确的),问题在于您必须将 typename 放在依赖模板的类型之前。

然而,最好的解决方案是使用auto让编译器自己推断类型。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM