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

编程入门 行业动态 更新时间:2024-10-27 23:17:52
本文介绍了如何在编译时检测类型是否为shared_ptr的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧! 问题描述

我想找到一种确定类型是否为shared_ptr的模板化方法,并以此为基础对函数进行新的专业化处理。

I want to get a templatized way of finding if a type is a shared_ptr and based on that I want to have a new specialization of a function.

示例main函数是

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,那么我想使用其他函数。我在下面尝试过的

If t.value is shared_ptr then I want to have a different function specialization. I have tried below,

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谷物库的一部分。我正在尝试自定义。

But it does not seem to work. These are part of c++11 cereal library. Which I am trying to customize.

推荐答案

以下内容可能会有所帮助:

the following may help:

template<typename T> struct is_shared_ptr : std::false_type {}; template<typename T> struct is_shared_ptr<std::shared_ptr<T>> : std::true_type {};

然后您可以执行以下操作以获得正确的功能:

then you can do the following to get the correct function:

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; }

实时演示

更多推荐

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

本文发布于:2023-06-04 19:05:30,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/503301.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:类型   shared

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!