我想找到一种确定类型是否为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 Cereal 库的一部分。我正在尝试自定义。
最佳答案
以下内容可能会有所帮助:
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;
}
live demo