我正在使用一个指向函数的数组.我写了这样的代码,因为一些元素不能用函数模板表达.
extern void zero(); // isr 0 is defined somewhere else void one() { // isr 1 } template <std::size_t N> void Nth() { // isr N } using func = void (*)(); constexpr func interrupt_vector[256] = { &zero,&one,&Nth<2>,&Nth<3>,... &Nth<254>,&Nth<255>,};
我已经阅读了关于静态表生成与可变模板,但那些是关于初始化整个数组.
我如何简化代码?
@实际上它是中断向量的一部分.由于它应该直接调用,所以我不能使用模板专门化
template <> void Nth<0>() { zero(); }
@@编辑代码.我认为这个事情很混乱.
解决方法
如果您可以更改使用std :: array,那么这样的工作.
using func = void (*)(); template<int...> struct index_sequence { }; template<int From,int N,int... Is> struct make_index_sequence_from : make_index_sequence_from<From,N - 1,Is...> { }; template<int From,int... Is> struct make_index_sequence_from<From,From,Is...> : index_sequence<Is...> { }; template<int... Is> constexpr std::array<func,256> make_interrupt_vector_array(index_sequence<Is...>) { return {{zero,one,Nth<Is>...}}; } constexpr std::array<func,256> make_interrupt_vector_array() { return make_interrupt_vector_array(make_index_sequence_from<2,256>()); } constexpr auto interrupt_vector = make_interrupt_vector_array();