gpt4 book ai didi

c++ - 为什么简单的双映射 (std::string <-> int) 不起作用?

转载 作者:行者123 更新时间:2023-11-30 02:58:20 25 4
gpt4 key购买 nike

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,正如我在这篇博文中提出的问题:Why I can use const char* as key in std::map<std::string, int>

最佳答案

您的代码尝试将非 const 引用绑定(bind)到一个临时引用(即 std::string,它是从您的 const char[ ])。只有 const 引用可以绑定(bind)到临时对象。

尝试:

  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("%s\n", m[2].c_str());
return 0;
}

关于c++ - 为什么简单的双映射 (std::string <-> int) 不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13727679/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com