9

我尝试创建一个类来轻松管理资源(ResourceManager)。

为此,我将模板与 C++11 一起使用。

这就是我所做的:


template<class K,class T>
class ResourceManager
{
    public:
        ResourceManager();
        ~ResourceManager();

        /* code */

        void clear();

    private : 
        std::unordered_map<K,T> resource;

        template <bool b>
        void clear();
};

 template<class K,class T>
 void ResourceManager<K,T>::clear()
 {
    clear<std::is_pointer<T>::value>();
 };

 template<class K,class T>
 template<bool b>
 void ResourceManager<K,T>::clear<b>()
 {
    for(auto& x:resource)
    delete x.second;
    resource.clear();
 }

 template<class K,class T>
 template<>
 void ResourceManager<K,T>::clear<false>()
 {
    resource.clear();
 }

简而言之,如果T是指针(自动删除),我会尝试有不同的表现。

我尝试使用std::enable_if,但我不明白它是如何运作的,以及这是否是正确的方法。

如果有人可以帮助我...


代码可以在这里找到:https ://github.com/Krozark/ResourceManager

4

1 回答 1

11

您可以只使用基于重载和标签调度的解决方案。您的clear()成员函数将以这种方式定义:

void clear()
{
    do_clear(std::is_pointer<T>());
}

并且您的类模板将包括两个重载do_clear(),如下所示:

template<class K,class T>
class ResourceManager
{

    // ...

private:

    void do_clear(std::true_type);
    void do_clear(std::false_type);

};

这是这两个成员函数的定义:

template<class K, class T>
void ResourceManager<K, T>::do_clear(std::true_type)
{
    for(auto& x:resource)
    delete x.second;
    resource.clear();
}

template<class K, class T>
void ResourceManager<K, T>::do_clear(std::false_type)
{
    resource.clear();
}

但是请注意,您始终可以选择使用智能指针和其他 RAII 资源包装器,以避免delete显式调用原始指针。

于 2013-05-14T23:19:48.617 回答