constexpr 使用标准库算法

use*_*729 2 c++ iterator dereference constexpr c++17

使用 C++17/C++20 x64 gcc/clang 构建时,以下代码段会产生编译错误,而通过直接取消引用迭代器*std::max_element(std::begin(arr), std::end(arr))工作正常。关于为什么的任何想法?我还观察到了自 C++20 以来已成为 constexpr 的其他标准算法的类似行为,例如std::upper_bound

int main()
{
    constexpr std::array<int,5> arr = {1,2,3,4,5};
    constexpr auto it = std::max_element(std::begin(arr), std::end(arr));
}
Run Code Online (Sandbox Code Playgroud)
source>:11:73: error: '(((std::array<int, 5>::const_pointer)(& arr.std::array<int, 5>::_M_elems)) + 16)' is not a constant expression
   11 |     constexpr auto it  = std::max_element(std::begin(arr), std::end(arr));
      |           
Run Code Online (Sandbox Code Playgroud)

Hol*_*Cat 7

it必须存储一个指向 的元素的指针arr

由于arris not static,它位于堆栈上,因此无法在编译时确定其地址。

如果你使arr static.

  • @user3882729 我不确定我会这么说。`std::max_element` 调用*是*可以在编译时“自行”评估的东西。但是,当您尝试使用它来初始化“constexpr”变量时,该评估产生的值需要接受进一步的测试。除非“arr”是“static”,否则包含“&amp;arr”的迭代器不会通过,但取消引用的值是原子的并且会通过。迭代器“是‘constexpr’”,因为它被允许作为‘constexpr’计算中的*中间*,而不是作为结果。 (2认同)