在C++中键入擦除:boost::shared_ptr和boost::函数是如何工作的
Type erasure in C++: how boost::shared_ptr and boost::function work?
键入擦除-您就是这么称呼它的吗?
boost::shared_ptr
如何存储其deleter,boost::function
如何存储其函数对象?
有教这个把戏的教程吗?
使用类型擦除函数对象的运行时成本是多少?
这个想法很简单,您可以定义一个基类,该基类具有一个具有所需功能的接口,然后从中继承。由于被擦除的类型类只使用该接口,因此下面的实际类型是被遗忘的和被擦除的。或者,如果唯一需要的接口可以表示为自由函数,则可以存储指向自由函数的指针。
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
的特殊情况下,删除程序被存储为引用计数对象的一部分,该对象由指针持有。
相关文章:
- boost信号和插槽在不同的线程中不工作(使用boost::asio::io_service)
- 多个共享工作池,带 Boost::Fiber
- Boost Log的琐碎记录器"lazy evaluation"是如何工作的?
- boost::make_shared 失败,但 std::make_shared 工作
- 来自 boost 的 udp 服务器不适用于多线程,但仅在主线程上工作
- boost::asio 使用 post() 时没有调用处理程序,当直接调用函数时有效(io_context有工作)
- thread_specific_pointer可以在哪些平台上工作而无需 boost::thread?
- 如果我将作品张贴到线程池,并且线程已经在Boost中工作,会发生什么
- 防止Boost :: Asio :: IO_Context在没有更多工作时返回
- Boost::线程如何在主线程和工作线程之间同步
- 尝试在Visual Studio工作时使用CLION的Boost 1.69.0,但给出了奇怪的MINGW错误
- 很难从c++boost库中获得barycentric_riomic来按照我的需要工作
- boost::asio绞线缠绕的线程无法立即工作
- 无法让 matplotlib 事件处理程序与 Boost.Python 一起工作
- C++11: boost::make_tuple 与 std::make_tuple 有何不同?
- 在linux下使用boost::thread创建一个boost::asio工作线程
- 阻止Boost Asio工作线程
- Boost:等待工作线程等待条件变量
- 如何使boost::exponential_distribution工作
- 我如何获得Boost.LexicalCast工作