c – 在编译时切换std :: array的每个元素

前端之家收集整理的这篇文章主要介绍了c – 在编译时切换std :: array的每个元素前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我想将一个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

猜你在找的C&C++相关文章