如何在结构模板中自动推断出C-Array的大小?

时间:2014-10-28 14:28:34

标签: c++ arrays templates c++11 initialization

我有一个关于如何自动推断结构模板中C-Array大小的问题。 来自嵌入式系统世界,我对ROMable结构感兴趣以节省RAM。

这是交易:

我有很多不同的结构,比如

struct  struct_1
{
    uint8_t     const   variable1;
    uint16_t    const   variable2;
};

在结构模板中,我存储一个指向C数组的指针,该数组包含结构元素和该C数组的大小,如下所示。

template<typename T>
struct config_data
{
    T    const  * const  ptr_to_c_array;
    uint8_t       const  arraySize;
};

template <typename T, uint8_t array_size >
constexpr uint8_t  getArraySize ( T  (&)[ array_size ] )    
{
    return array_size;
};

int main(){

struct_1                  const  array_1[]      =  { {2,5},{1,9},{20,20} };
uint8_t                   const  arraySize_1    =  getArraySize( array_1 );
config_data <struct_1>    const  config_data_1  =  { array_1, arraySize_1 };

}

这是我的问题:

如何使用sizeof [array] / sizeof(array [0])或getArraySize模板,自动推断出我的c-array大小的结构模板,而不是明确地给它大小?

我希望有类似的东西:

template < typename T, uint8_t  array_size >
struct config_data_new
{
    T    const  * const ptr_to_c_array;
    uint8_t       const arraySize = array_size;    //clearly, does not work   
};

int main(){

struct_1                     const  config_array_1[] =  { {2,5}, {1,9}, {20,20} };
config_data_new <struct_1>   const  config_file_new  =  { config_array_1 };           

uint8_t   const size  =  config_file_new.arraySize;

}

是否可以在模板config_data _new中推断数组大小,类似于模板getArraySize?

1 个答案:

答案 0 :(得分:4)

您可以执行以下操作:

template <typename T, std::size_t N>
constexpr config_data<T> make_config_data(const T (&a)[N])
{
    return {a, N};
}

Live example