模板启用它是指针

template enable if is pointer

本文关键字:指针 启用      更新时间:2023-10-16

我尝试创建一个类来轻松管理资源(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

您可以使用基于重载和标记调度的解决方案。您的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