为什么一个简单的bimap(std::string <-> int)不起作用?


一个

令人费解的模板和类型转换问题如下所示C++...为了让我的生活更轻松,我定义了一个模板类来使用类 BiMap 对一对一关系进行建模:

#include <stdio.h>
#include <stdlib.h>
#include <map>   
#include <string>
template<class T1, class T2>
class BiMap {
 public:
  T2& operator[] (T1& t1) {
    return d1[t1];
  }
  T1& operator[] (T2& t2) {
    return d2[t2];
  }
 private:
  std::map<T1, T2> d1;
  std::map<T2, T1> d2;
};

int main(int argc, char *argv[])
{
  BiMap<std::string, int> m;
  m["1"] = 2;
  m[2] = 3;
  printf("%d", m["1"]);
  printf("%d", m[2]); 
  return 0;     
}

但是我得到这个编译错误:

testPedigree.cpp:45: error: no match for ‘operator[]’ in ‘m["1"]’
testPedigree.cpp:16: note: candidates are: T2& BiMap<T1, T2>::operator[](T1&) [with T1 = std::basic_string<char, std::char_traits<char>, std::allocator<char> >, T2 = int]
testPedigree.cpp:19: note:                 T1& BiMap<T1, T2>::operator[](T2&) [with T1 = std::basic_string<char, std::char_traits<char>, std::allocator<char> >, T2 = int]

我期待C++会自动将 const char* 转换为 std::string,因为我在这篇文章中提出了这个问题:为什么我可以在 std::map<std::string,>

您的代码尝试将非const引用绑定到临时引用(即从const char[]隐式创建的std::string)。只有const引用可以绑定到临时引用。

尝试:

  T2& operator[] (const T1& t1) {
    return d1[t1];
  }
  T1& operator[] (const T2& t2) {
    return d2[t2];
  }

示例中还有其他一些琐碎的错误。这是一个经过更正、测试的程序:

#include <stdio.h>
#include <stdlib.h>
#include <map>
#include <string>
template<class T1, class T2>
class BiMap {
 public:
  T2& operator[] (const T1& t1) {
    return d1[t1];
  }
  T1& operator[] (const T2& t2) {
    return d2[t2];
  }
 private:
  std::map<T1, T2> d1;
  std::map<T2, T1> d2;
};

int main(int argc, char *argv[])
{
  BiMap<std::string, int> m;
  m["1"] = 2;
  m[2] = "3";
  printf("%d", m["1"]);
  printf("%sn", m[2].c_str());
  return 0;
}

相关内容

最新更新