当前位置:  开发笔记 > 编程语言 > 正文

如何在编译时检测类型是否为shared_ptr

如何解决《如何在编译时检测类型是否为shared_ptr》经验,为你挑选了2个好方法。

我希望得到一种模板化的方法来查找类型是否为shared_ptr,并且基于我希望有一个新的函数特化.

示例主要功能是,

template  inline
void CEREAL_LOAD_FUNCTION_NAME( RelaxedJSONInputArchive & ar,    NameValuePair & t )
{
    std::cout << " CEREAL_LOAD_FUNCTION_NAME NameValuePair 1 " << std::endl;
     ar.setNextName( t.name );
     ar( t.value );
}

如果t.value是shared_ptr,那么我想要一个不同的函数特化.我试过下面,

template  inline
typename std::enable_if::value, void>::type
CEREAL_LOAD_FUNCTION_NAME( RelaxedJSONInputArchive & ar, NameValuePair & t )
 {
    std::cout << " CEREAL_LOAD_FUNCTION_NAME NameValuePair 2 " << std::endl;
   ar.setNextName( t.name );
   ar( t.value );
  }

但它似乎没有用.这些是c ++ 11谷物库的一部分.我正在尝试自定义.



1> Biggy Smith..:

以下可能有所帮助:

template struct is_shared_ptr : std::false_type {};
template struct is_shared_ptr> : std::true_type {};

然后你可以做以下事情来获得正确的功能:

template  
typename std::enable_if().value)>::value, void>::type
func( T t )
{
    std::cout << "shared ptr" << std::endl;
}

template  
typename std::enable_if().value)>::value, void>::type
func( T t )
{
    std::cout << "non shared" << std::endl;
}

现场演示



2> François And..:

这是模板专业化的基本案例.以下是确定类型T是否为a的类型特征shared_ptr.它可以以std::is_pointer您已经使用的相同方式使用.

#include 
#include 

template
struct is_shared_ptr : std::false_type {};

template
struct is_shared_ptr> : std::true_type {};

示范:

static_assert(is_shared_ptr>::value == true, "");
static_assert(is_shared_ptr::value == false, "");

推荐阅读
mobiledu2402851373
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有