我希望得到一种模板化的方式来查找某个类型是否为shared_ptr,并且基于此我希望对函数进行新的特化。
示例主要功能是,
template <class T> inline
void CEREAL_LOAD_FUNCTION_NAME( RelaxedJSONInputArchive & ar, NameValuePair<T> & t )
{
std::cout << " CEREAL_LOAD_FUNCTION_NAME NameValuePair 1 " << std::endl;
ar.setNextName( t.name );
ar( t.value );
}
如果t.value是shared_ptr,那么我想要一个不同的函数专门化。 我在下面尝试过,
template <class T> inline
typename std::enable_if<is_pointer<T>::value, void>::type
CEREAL_LOAD_FUNCTION_NAME( RelaxedJSONInputArchive & ar, NameValuePair<T> & t )
{
std::cout << " CEREAL_LOAD_FUNCTION_NAME NameValuePair 2 " << std::endl;
ar.setNextName( t.name );
ar( t.value );
}
但它似乎不起作用。这些是c ++ 11谷物库的一部分。我正在尝试自定义。
答案 0 :(得分:9)
以下内容可能有所帮助:
template<typename T> struct is_shared_ptr : std::false_type {};
template<typename T> struct is_shared_ptr<std::shared_ptr<T>> : std::true_type {};
然后您可以执行以下操作以获得正确的功能:
template <class T>
typename std::enable_if<is_shared_ptr<decltype(std::declval<T>().value)>::value, void>::type
func( T t )
{
std::cout << "shared ptr" << std::endl;
}
template <class T>
typename std::enable_if<!is_shared_ptr<decltype(std::declval<T>().value)>::value, void>::type
func( T t )
{
std::cout << "non shared" << std::endl;
}
答案 1 :(得分:5)
这是template specialization的基本案例。以下是确定类型T是否为shared_ptr
的类型特征。它可以与您已使用的std::is_pointer
相同的方式使用。
#include <memory>
#include <type_traits>
template<class T>
struct is_shared_ptr : std::false_type {};
template<class T>
struct is_shared_ptr<std::shared_ptr<T>> : std::true_type {};
示范:
static_assert(is_shared_ptr<std::shared_ptr<int>>::value == true, "");
static_assert(is_shared_ptr<int>::value == false, "");
答案 2 :(得分:0)
如果提供的类型本身是某个未知类型T的std :: shared_ptr,那么以下SFINAE的使用应该会有所帮助!由于所有智能指针都提供成员类型“ element_type
”,因此我们可以专门针对std::shared_ptr<T>
,std::weak_ptr<T>
和std::unique_ptr<T>
进行以下操作:
template<typename T, typename Enable = void>
struct is_smart_pointer
{
enum { value = false };
};
template<typename T>
struct is_smart_pointer<T, typename std::enable_if<std::is_same<typename std::remove_cv<T>::type, std::shared_ptr<typename T::element_type>>::value>::type>
{
enum { value = true };
};
template<typename T>
struct is_smart_pointer<T, typename std::enable_if<std::is_same<typename std::remove_cv<T>::type, std::unique_ptr<typename T::element_type>>::value>::type>
{
enum { value = true };
};
template<typename T>
struct is_smart_pointer<T, typename std::enable_if<std::is_same<typename std::remove_cv<T>::type, std::weak_ptr<typename T::element_type>>::value>::type>
{
enum { value = true };
};