这previously answered question解释了为什么我在下面发布的代码不起作用。我有一个后续问题:是否存在概念上等效的解决方法,即实现编译时字符串连接,但是以C ++ 11实际支持的方式实现?使用std :: string是完全不必要的。
constexpr std::string foo() { return std::string("foo"); }
constexpr std::string bar() { return std::string("bar"); }
constexpr std::string foobar() { return foo() + bar(); }
答案 0 :(得分:7)
编译时“字符串”连接:
#include <iostream>
#include <string>
template <char ... CTail>
struct MetaString
{
static std::string string()
{
return std::string{CTail...};
}
};
template <class L, class R>
struct Concatenate;
template <char ... LC, char ... RC>
struct Concatenate<MetaString<LC ... >, MetaString<RC ... >>
{
typedef MetaString<LC ..., RC ... > Result;
};
int main()
{
typedef MetaString<'f', 'o', 'o'> Foo;
typedef MetaString<'b', 'a', 'r'> Bar;
typedef typename Concatenate<Foo, Bar>::Result FooBar;
std::cout << Foo::string() << std::endl; // foo
std::cout << Bar::string() << std::endl; // bar
std::cout << FooBar::string() << std::endl; // foobar
}
答案 1 :(得分:3)
Sprout C ++库提供constexpr字符串。看到: https://github.com/bolero-MURAKAMI/Sprout/blob/master/libs/string/test/string.cpp