比较地图对象及其引用C++
Compare a map object and its reference C++
我有以下地图
map<int,string> m1;
map<int,string> m2;
call(m1);
call(m2);
template<typename T>
void call(T &m)
{
// Compare if m == m1
How to do?
}
我需要知道在运行时在当前函数中调用了哪些m1
和m2
。
如果要根据地图的内容进行检查,可以使用operator==
:
template<typename T>
void call(T &m)
{
if (m == m1)
...
}
如果要确定它们是否是同一实例,由于参数是通过引用传递的,因此可以比较它们的地址:
template<typename T>
void call(T &m)
{
if (&m == &m1)
...
}
正如@Smeeheey指出的,您需要考虑如何提供比较对象(即 m1
或其地址)在模板函数中,从您的代码段中不清楚。
为了改进接受的答案,如果要避免由于在map<int, string>
以外的类型上调用函数而导致call
编译器错误,则需要一个模板帮助程序函数:
template <typename T, typename U>
bool is_equal(const T& t, const U& u)
{
return false;
}
template <typename T>
bool is_equal(T& t, T& u)
{
return &t == &u;
}
template<typename T>
void call(T &m)
{
// Compare if m == m1
if(is_equal(m, m1))
std::cout << "Yes";
else
std::cout << "No";
}
相关文章:
- 将对象数组的引用传递给函数
- 什么时候在C++中返回常量引用是个好主意
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 何时在引用或唯一指针上使用移动语义
- 如何在c++中使用引用实现类似python的行为
- 编译C++时未定义的引用
- Ctypes wstring通过引用传递
- c++r值引用应用于函数指针
- 理解c++中的引用
- C++取消引用指针.为什么会发生变化
- 如何修复此错误:未定义对"距离(浮点数,浮点数,浮点数,浮点数,浮点数)"的引用
- 我的项目不会像"undefined reference to `grpc::g_core_codegen_interface'"那样使用未定义的引用错误进行编译
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- 强制转换为引用类型
- 引用一个已擦除类型(void*)的指针
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 具有默认值的引用获取函数
- 如何使用基类指针引用派生类成员
- 使用取消引用的指针的多态性会产生意外的结果.为什么?
- 如何引用基类的派生类?