C 虚拟模板方法
所呈现的场景涉及一个具有虚拟模板方法 setData 和 getData 的抽象类,旨在动态设置和检索基于提供的标识符的各种类型的数据。然而,正如问题所承认的,C 中不直接支持这样的构造。
要解决此限制,有两种主要方法:
删除静态多态性
一种选择是删除静态多态性(模板)并引入中间存储机制。 AbstractComputation 类可以定义一个非模板化的 ValueStore,负责根据标识符存储和检索数据:
<code class="cpp">class ValueStore { public: template <typename T> void setData(std::string const &id, T value) {...} template <typename T> T getData(std::string const &id) {...} }; class AbstractComputation { public: template <typename T> void setData(std::string const &id, T value) { m_store.setData(id, value); } template <typename T> T getData(std::string const &id) const { return m_store.getData<T>(id); } private: ValueStore m_store; };</code>
派生类可以直接访问 ValueStore,而不需要运行时多态性。
删除运行时多态性
或者,可以在删除静态多态性的同时保留运行时多态性。这涉及到对基类执行类型擦除:
<code class="cpp">class AbstractComputation { public: template <typename T> void setData(std::string const &id, T value) { setDataImpl(id, boost::any(value)); } template <typename T> T getData(std::string const &id) const { boost::any res = getDataImpl(id); return boost::any_cast<T>(res); } protected: virtual void setDataImpl(std::string const &id, boost::any const &value) = 0; virtual boost::any getDataImpl(std::string const &id) const = 0; };</code>
boost::any 是一种可以存储任何类型的值并允许安全检索数据的类型。类型擦除是通过将 boost::any 对象作为参数传递给虚拟方法来执行的,虚拟方法必须在派生类中实现。
以上是如何在 C 中实现虚拟模板方法?的详细内容。更多信息请关注PHP中文网其他相关文章!