我想實作以下邏輯,我不確定是否可能:
#include <stddef.h>
#include <array>
template<size_t SIZE>
constexpr std::array<const char*, 1> fun(const char (&name)[SIZE])
{
return {name};
}
template<size_t SIZE_1, size_t SIZE_2>
constexpr std::array<const char*, 2> fun(const char (&name1)[SIZE_1], const char (&name2)[SIZE_2])
{
return {name1, name2};
}
// I would like to do something like this:
template<size_t... SIZES>
constexpr std::array<const char*, sizeof...(SIZES)> fun(const char (&/*???*/)[SIZES]/*...*/)
{
//???
}
int main()
{
static constexpr auto fun1 = fun("aaa");
static constexpr auto fun2 = fun("aaa", "bbb");
//static constexpr auto funN = fun("aaa", "bbb", "ccc");
}
將引數作為原始陣列獲取以對它們進行額外的編譯時魔術非常重要。
uj5u.com熱心網友回復:
...使用型別別名知道放在哪里要簡單得多
template<std::size_t N>
using chars = const char (&)[N];
template<std::size_t... SIZES>
constexpr std::array<const char*, sizeof...(SIZES)> fun(chars<SIZES>... names)
{
return { names... };
}
在coliru上看到它
轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/312611.html
