类型擦除——你就是这么称呼它的吗?
How boost::shared_ptr
存储其删除器以及如何存储boost::function
存储它的函数对象?
有没有教程可以教这个技巧?
使用类型擦除函数对象的运行时成本是多少?
这个想法很简单,您定义一个基类,该基类具有包含您所需功能的接口,然后从中继承。自从类型已删除类仅使用该接口,下面的实际类型是忘记了 and erased。或者,如果唯一需要的接口可以表示为自由函数,则可以存储指向自由函数的指针。
namespace detail {
struct deleter_base {
virtual ~deleter_base() {}
virtual void operator()( void* ) = 0;
};
template <typename T>
struct deleter : deleter_base {
virtual void operator()( void* p ) {
delete static_cast<T*>(p);
}
};
}
template <typename T>
class simple_ptr {
T* ptr;
detail::deleter_base* deleter;
public:
template <typename U>
simple_ptr( U* p ) {
ptr = p;
deleter = new detail::deleter<U>();
}
~simple_ptr() {
(*deleter)( ptr );
delete deleter;
}
};
这是一个非常简化的智能指针,但想法就在那里。在特定情况下shared_ptr
, the deleter存储为引用计数对象的一部分,由指针保存。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)