std::for_each易忽略点

发布时间 2023-09-03 11:03:06作者: ChebyshevTST

  以下代码为修改vector内部的每一个元素,使其每个元素大小变为原来的平方。

    std::vector v1{1, 2, 4, 2};

    std::for_each(begin(v1), end(v1), [](auto& n) {
        return n * n;
    });

    for (const auto& item : v1)
        std::cout << item << ' ';

  但是输出结果依旧是1,2,4,2。

 

  在cppreference官网for_each的描述中,有这么一段话:

  For both overloads, if the iterator type (InputIt/ForwardIt) is mutable, f may modify the elements of the range through the dereferenced iterator. If f returns a result, the result is ignored.

  也就是说,有返回值的函数是会被忽略掉的,所以就造成了上面的结果。

  另外一方面,可以看到for_each的实现:

template<class InputIt, class UnaryFunction>
constexpr UnaryFunction for_each(InputIt first, InputIt last, UnaryFunction f)
{
    for (; first != last; ++first)
        f(*first);
 
    return f; // implicit move since C++11
}

  若f是有返回值的函数(可以结合最上面的demo来看),其返回了n的平方而没有实质对n做修改操作,所以最终结果也没有发生变化。