c – 在编译时切换std :: array的每个元素
发布时间:2020-12-16 06:03:38 所属栏目:百科 来源:网络整理
导读:我想将一个std ::数组转换为另一个std ::数组,通过一个特定的数字来显示每个元素. 我现在所看到的显然不行: #include array#include iostream#include utilitytemplate class T,size_t... Is,size_t Nconstexpr std::arrayT,N multiply(std::arrayT,N const
我想将一个std ::数组转换为另一个std ::数组,通过一个特定的数字来显示每个元素.
我现在所看到的显然不行: #include <array> #include <iostream> #include <utility> template <class T,size_t... Is,size_t N> constexpr std::array<T,N> multiply(std::array<T,N> const &src,std::index_sequence<Is...>) { return std::array<T,N>{{src[Is]...}}; // How can I multiply each of src's elements? } int main(int argc,char *argv[]) { constexpr std::array<int,3> arr = {1,2,3}; constexpr auto t = multiply(arr,std::make_index_sequence<3>{}); for (auto &el : t) std::cout << el << std::endl; return 0; } 我的问题是:如何在编译时迭代每个元素,或者如何在编译时应用相同的函数(在我的情况下乘以2)? 解决方法
您可以按照以下方式进行操作:
template<typename T> constexpr T mult(T const &a,T const &b) { return a * b; } template <class T,std::index_sequence<Is...>) { return std::array<T,N>{{mult(src[Is],src[Is])...}}; } Live Demo 或者如果要乘以一个数字,您可以更改为: template<typename T> constexpr T mult(T const &a,std::index_sequence<Is...>,T const &mul) { return std::array<T,mul)...}}; } Live Demo 如cppreference所解释: 一个模式后跟一个省略号,其中至少有一个参数包的名称至少出现一次,将被扩展为模式的零个或多个逗号分隔的实例化,其中参数包的名称被每个类型替换从包,顺序.包扩展只能在包扩展上下文中发生.这些基本上是: >支撑初始化 编辑: 正如T.C.指出了你也可以这么简单的评论: template <class T,N>{{(src[Is] * mul)...}}; } Live Demo (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |