2

我有以下 C++11 兼容代码,我需要用不支持“.at”的 C++98 编译它。如何重写它以与 C++98 兼容?

String suffix("sss");
headers_t& meta = ...;
typedef std::map<std::string, std::string> headerpair_t;
typedef std::map<std::string, headerpair_t> addheader_t;

addheader_t addheader;

for(headerpair_t::const_iterator piter = addheader.at(suffix).begin(); piter !=  addheader.at(suffix).end(); ++piter){
    // Adding header
    meta[(*piter).first] = (*piter).second;
}
4

2 回答 2

7

只需创建一个at()模仿 C++11 功能的函数std::map<...>::at()

template <typename K, typename V, typename C, typename A>
V const& at(std::map<K, V, C, A> const& m, K const& k) {
    typename std::map<K, V, C, A>::const_iterator it(m.find(k));
    if (it == m.end()) {
        throw std::out_of_range("key not found in map");
    }
    return it->second;
}

请注意,at()在循环的每次迭代中调用是一个坏主意!搜索 a在理论上std::map<...>有效的,但这并不意味着它在实践中很快!您最好只搜索一个相关节点,然后继续使用它。

于 2013-12-30T18:47:17.060 回答
2

你不应该at()在这样的for循环条件中使用。元素在迭代之间不会发生变化,并且每次都检索它会产生开销。所以你应该使用它来检索它find,然后在迭代器上循环:

addheader_t::const_iterator header_iter = addheader.find(suffix); // Retrieve the element

if (header_iter != addheader.end()) // Check that it does exist
{
  // Retrieve the sub-map in the pair
  const headerpair_t& header_pair_map = it->second;

  // Loop on the elements
  for (headerpair_t::const_iterator it = header_pair_map.begin(); header_pair_map.end(); ++it)
  {
    // Use insert to avoid a useless element construction
    // Use also `std::make_pair`, but can we directly insert the pair from headerpair ?
    meta.insert(std::make_pair(it->first, it->second));
  }
}
于 2013-12-30T19:10:35.870 回答