简化std :: string构造,包括在C ++中连接整数

时间:2011-06-27 15:28:53

标签: c++ string integer concatenation

寻找以下更优雅的快捷方式:

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 ++工具来实现吗?顺便说一句,提升不是一种选择。

4 个答案:

答案 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。