在编译时解析字符串

时间:2019-02-15 16:31:23

标签: c++ c++17

我正在尝试编译以下代码:

#include <string_view>

constexpr size_t get_member_count(const char * va)
{
    const char * p = va;        
    size_t count = 1;
    while (*p != 0)
    {
        if (*p++ == ',')
        {
            ++count;
        }
    }

    return count;
}

template <const char * va>
constexpr auto get_member_names()
{
    constexpr size_t count = get_member_count(va);
    static std::basic_string_view<char> v[count];
    //fill the array here
    return v;
}

int main()
{
    constexpr const char * mem_list = "a, b, c";
    constexpr auto v = get_member_names<mem_list>();
}

MSVC 2017和GCC 9都不编译'get_member_names()'分别告诉'找不到匹配的重载函数'或'没有匹配的调用函数'。

函数get_member_count可以编译,我可以这样做:

constexpr size_t mem_count = get_member_count(mem_list);

1 个答案:

答案 0 :(得分:3)

来自[temp.arg.nontype]/2

  

对于引用或指针类型的非类型模板参数,或者对于类类型或其子对象的非类型模板参数中的引用或指针类型的每个非静态数据成员,引用或指针值不得分别引用或作为以下地址:

     
      
  • [...]
  •   
  • 字符串文字([lex.string]),
  •   
  • [...]
  •   

所以这个:

constexpr const char * mem_list = "a, b, c";
constexpr auto v = get_member_names<mem_list>();

无法工作。您必须制作一个静态存储持续时间数组。像这样:

static const char mem_list[] = "a, b, c";
constexpr auto v = get_member_names<mem_list>();