寻找以下更优雅的快捷方式:
for (int i=1; i<=maxNum; i++)
{
std::ostringstream s;
s << i;
std::string group1 = "group1_" + s.str();
std::string group2 = "group2_" + s.str();
.
.
.
val = conf->read(group1.c_str());
.
.
.
}
任何人都可以想到一种优雅的方式:
conf->read({SOMEMACRO or function}("group1_", i));
可以使用内置的C ++工具来实现吗?顺便说一句,提升不是一种选择。
答案 0 :(得分:2)
为什么不能这样:
inline std::string construct_group_id(int n, int i)
{
std::ostringstream s;
s << "group" << n << "_" << i;
return s.str();
}
答案 1 :(得分:2)
我想我会使用Boost的lexical_cast(有点受限制)副本:
template <class T, class U>
T lexical_cast(U const &input) {
std::stringstream buffer;
buffer << input;
T ret;
buffer >> ret;
return ret;
}
for (int i=0; i<maxNum; i++)
val = conf->read("group1_" + lexical_cast<std::string>(i));
答案 2 :(得分:0)
这是itoa
周围的静态包装器。它不是线程安全的。
static const char * static_itoa( const int val )
{
static char buff[20];
return itoa( val, buff, 10 );
}
答案 3 :(得分:0)
这里有一个小助手功能:
inline std::string myitoa(size_t n)
{
std::string res = n ? "" : "0";
while(n) { res += '0' + (n % 10); n /= 10; }
return std::string(res.rbegin(), res.rend());
}
for (size_t i = 0; i < N; ++i)
{
const std::string n = myitoa(i+1);
std::string g1 = "group1_" + n;
/* ... */
}
这要求您的编码连续存储数字字符,N小于10。