模板检测T是指针还是类
Template detects if T is pointer or class
考虑以下代码:
class MyClass
{
...
};
template <typename Object>
class List
{
public:
void insert(const Object & x)
{
// call when Object is MyClass
}
void insert(const Object & x)
{
// call when Object is MyClass*
}
}
int main()
{
MyClass a;
List<MyClass> lst;
List<MyClass*> plst;
lst.insert(a);
plst.insert(new Myclass);
return 0;
}
如何根据模板是类还是指针来告诉编译器调用不同的方法?
如何修复上面的代码?
您可以使用std::is_pointer
和std::enable_if
:的组合
#include <type_traits>
#include <iostream>
class MyClass
{
};
template <typename Object>
class List
{
public:
template<class T=Object>
void insert(T t, typename std::enable_if<std::is_pointer<T>::value >::type* = 0)
{
std::cout << "insert pointer" << std::endl;
}
template<class T=Object>
void insert(T t, typename std::enable_if<!std::is_pointer<T>::value >::type* = 0)
{
std::cout << "insert non-pointer" << std::endl;
}
};
int main()
{
MyClass a;
List<MyClass> lst;
List<MyClass*> plst;
lst.insert(a);
plst.insert(new MyClass());
return 0;
}
现场示例:https://ideone.com/CK8Zdo
这将允许您将指针和非指针都插入到指针或非指针列表中。如果你想限制它,你可以使用这个:
#include <type_traits>
#include <iostream>
class MyClass
{
};
template <typename Object>
class List
{
public:
template<class T=Object>
void insert(T t, typename std::enable_if<std::is_same<T,Object>::value&&std::is_pointer<T>::value >::type* = 0)
{
std::cout << "insert pointer" << std::endl;
}
template<class T=Object>
void insert(const T& t, typename std::enable_if<std::is_same<T,Object>::value&&!std::is_pointer<T>::value >::type* = 0)
{
std::cout << "insert non-pointer" << std::endl;
}
};
int main()
{
MyClass a;
List<MyClass> lst;
List<MyClass*> plst;
lst.insert(a);
// plst.insert(a); // compiler error
// lst.insert(new MyClass()); // compiler error
plst.insert(new MyClass());
return 0;
}
现场示例:https://ideone.com/3DtBfr
我知道我的答案并不完全是关于你的问题,但也许它会有所帮助。
我相信您的意图是让List类有一个insert方法(而不是两个(,这个方法的行为应该取决于您的模板参数。为此你可以为指针编写一个专门的类。然后,基本模板将用于非指针类型,而专门化将用于指针类型。
你的代码看起来是这样的:
template <typename Object>
class List
{
public:
void insert(const Object & x)
{
// call when Object is MyClass
}
};
template <typename Object>
class List<Object *>
{
public:
void insert(Object * x)
{
// call when Object is MyClass*
}
};
void insert(const Object & x)
{
M_insert(x, dispatcher<std::is_pointer<Object>::value> );
}
在List
内部使用调度员
template <bool B> class dispatcher {};
using ObjectPtr = dispatcher<true>;
using ObjectValue = dispatcher<false>;
然后发送到M_insert
:
void M_insert(const Object &p, ObjectPtr) { // Object is a pointer }
void M_insert(const Object &p, ObjectValue) { // Object is not a pointer }
这里是一个活生生的例子。但是,我鼓励你确定你是否真的需要,并可能相应地修改你的设计。
这就完成了任务:
template <typename Object>
class List
{
public:
template<class C = Object>
void insert(const C & x)
{
// call when Object is MyClass
std::cout << "1" << "n" ;
}
template<class P = Object*>
void insert(P* p)
{
// call when Object is MyClass*
std::cout << "2" << "n" ;
}
} ;
下面是一个工作示例。
相关文章:
- SFINAE - 检测类型 T 是指针、数组还是带有随机访问运算符的容器,以及给定的值类型
- 对于循环不循环和检测字符数组 [指针和字符数组]
- 对于实际指针类型,用于检测类似指针(可取消引用)类型的模板函数失败
- 未检测到的空指针
- 未检测到越界指针算法?
- ***检测到的GLIBC *** MS2:free():无效指针:0xB7526FF4 ***
- gcc-如何检测基于指针的内存访问
- glibc 检测到 *** free() 无效指针
- "空指针已通过",用于检测轮廓
- *** glibc检测到*** free():无效的指针:
- 为引用计数的智能指针检测内存泄漏的设计模式
- c++提升线程glibc检测到无效指针
- 检测到指针引用可能存在内存泄漏
- 检测"内存泄漏"时,瓦尔格林德的真实指针是什么?
- glibc 检测到 free() 无效指针
- 为什么此循环不检测空指针?
- 如何检测或避免使用未初始化C++指针
- 奇怪的glibc检测到free()无效指针错误
- 是否有用于使用智能指针检测"Memory Leaks"的Valgrind
- QWidget::repaint:使用指针检测到递归重绘