Mr.*_*100 5 c++ templates shared-ptr c++11 cereal
我希望得到一种模板化的方法来查找类型是否为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 );
}
Run Code Online (Sandbox Code Playgroud)
如果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 );
}
Run Code Online (Sandbox Code Playgroud)
但它似乎没有用.这些是c ++ 11谷物库的一部分.我正在尝试自定义.
Big*_*ith 11
以下可能有所帮助:
template<typename T> struct is_shared_ptr : std::false_type {};
template<typename T> struct is_shared_ptr<std::shared_ptr<T>> : std::true_type {};
Run Code Online (Sandbox Code Playgroud)
然后你可以做以下事情来获得正确的功能:
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;
}
Run Code Online (Sandbox Code Playgroud)
这是模板专业化的基本案例.以下是确定类型T是否为a的类型特征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 {};
Run Code Online (Sandbox Code Playgroud)
示范:
static_assert(is_shared_ptr<std::shared_ptr<int>>::value == true, "");
static_assert(is_shared_ptr<int>::value == false, "");
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
2754 次 |
最近记录: |