

新闻资讯
技术学院std::accumulate是C++中基于迭代器的通用累加函数,适用于vector、原生数组等任意满足输入迭代器要求的范围;正确用法为accumulate(arr, arr + n, 0),初值不可随意省略以防类型不匹配或空范围未定义行为。
std::accumulate 是 C++ 标准库 头文件里提供的通用累加函数,不是专为数组设计的,而是作用于任意满足输入迭代器要求的范围(比如 std、原生数组、
::vectorstd::array,甚至 std::list)。它不关心容器类型,只依赖起始和结束迭代器。
常见误用是以为它“只能对 vector 求和”,其实对原生数组一样有效,只要传入指针即可——因为指针本身就是随机访问迭代器。
原生数组没有 .begin() / .end() 成员函数,必须手动计算边界。最容易出错的是传错右边界:它应指向「末尾元素的下一个位置」,不是末尾元素本身。
accumulate(arr, arr + n - 1, 0) → 少加最后一个元素accumulate(arr, arr + n, 0) → arr + n 是合法的“尾后指针”int arr[5]{1,2,3,4,5};),可用 std::size(arr) 替代手算 n
int arr[] = {10, 20, 30};
int sum = std::accumulate(arr, arr + std::size(arr), 0); // 结果 60std::accumulate 有两版重载:带初值和不带初值。不带初值版本(只有两个迭代器参数)要求容器元素类型支持 operator+,且返回类型与元素类型一致。但一旦初值类型不同,就必须显式提供——否则编译失败或隐式转换引发意外。
立即学习“C++免费学习笔记(深入)”;
int 数组用 0.0 当初值?得写 accumulate(..., 0.0),结果是 double
std::vector 求和,初值用 0(int)可能触发窄化,应写 0LL
在优化开启(-O2)的前提下,std::accumulate 和朴素 for 循环生成的汇编几乎一致,现代编译器能完全内联并展开。它没有运行时性能损失,但有两个隐含成本:
,而简单求和可能让人倾向只用 或
accumulate 反而难读,不如 range-based for + 显式逻辑std::reduce(可并行),但 accumulate 始终是严格顺序执行真正容易被忽略的是:它不做任何越界检查,也不验证迭代器有效性。传入野指针或 arr + n + 1,行为未定义——这和裸指针操作一样危险。