帶有引用參數的Constexpr 函數中的常數表達式
考慮以下程式碼片段:
template <size_t S1, size_t S2> auto concatenate(const std::array<uint8_t, S1> &data1, const std::array<uint8_t, S2> &data2) { std::array<uint8_t, data1.size() + data2.size()> result; // Error: non-type template argument is not a constant expression ... }
標準原理
此行為的原因在[expr.const]/4 中進行了解釋C 標準:
如果表達式計算的是引用引用類型的變數或資料成員的id-表達式,除非:std::array<uint8_t, S1 + S2> result;
以上是為什麼 `data1.size()` 不能在有參考參數的 `constexpr` 函數中運作?的詳細內容。更多資訊請關注PHP中文網其他相關文章!