最通用的方法是为 Wrapper 创建一个基类,比如 BaseWrapper,并在 BaseWrapper 上定义纯虚函数,然后在每个 Wrapper 类上实现这些纯虚函数。通过专业化,每个 Wrapper、Wrapper 都可以有自己的实现。完成此操作后,您可以使用指向 Base Type 的智能指针容器,并在闲暇时使用它。
有一些可能的捷径。例如,在您的示例中的简单情况下,我建议使用std::function
. 辅助函数有助于执行此操作。请注意,这只有在只有 1 个方法被调用时才有效。我还建议您operator()
直接定义包装器,这样您就不必使用绑定。
template<T>
std::function<void()> wrap(const T& x)
{
return std::bind(&Wrapper<T>::foo, Wrapper<T>(x));
}
int main(){
X x;
Y y;
std::vector<std::function<void()> > generic_container;
// A_GENERIC_CONTAINER should be able to store
// any number of heterogeneous objects of type Wrapper<T>
// where T can be any user defined type.
generic_container.push_back(wrap(x));
generic_container.push_back(wrap(y));
auto it = generic_container.begin();
auto end = generic_container.end();
while(it != end){
(*it)();
++it;
}
}
编辑:
我正在讨论的是一个非模板化的基础,您可以从中派生所有模板化包装器。这允许您调用您预定义的方法(并且必须由 Wrapper 实现),而无需知道所涉及的特定包装器类型。
class Base
{
public:
virtual ~Base() {};
virtual void foo() = 0;
};
template <typename T>
class Wrapper : public Base{
public:
Wrapper(const T& a):o(a){};
Wrapper(){};
//public methods
virtual void foo(){
//do stuff
};
private:
T o;
};
int main(){
X x;
Y y;
std::vector<std::shared_ptr<Base> > generic_container;
// A_GENERIC_CONTAINER should be able to store
// any number of heterogeneous objects of type Wrapper<T>
// where T can be any user defined type.
generic_container.push_back(std::make_shared<Wrapper<X>>(x));
generic_container.push_back(std::make_shared<Wrapper<Y>>(y));
auto it = generic_container.begin();
auto end = generic_container.end();
while(it != end){
it->foo();
++it;
}
}