加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – 如何在模板元编程中使用“默认”值

发布时间:2020-12-16 03:41:09 所属栏目:百科 来源:网络整理
导读:我面临以下问题: 我有一些通用容器,可以对类型进行一些操作.为简单起见,操作在请求时是线程安全的.并且,要求表示容器中的类型具有typedef std :: true_type needs_thread_safety;. struct thread_safe_item { typedef std::true_type needs_thread_safety;
我面临以下问题:

我有一些通用容器,可以对类型进行一些操作.为简单起见,操作在请求时是线程安全的.并且,要求表示容器中的类型具有typedef std :: true_type needs_thread_safety;.

struct thread_safe_item {
    typedef std::true_type needs_thread_safety;
    /* */ 
};

struct thread_unsafe_item {
    typedef std::false_type needs_thread_safety;
    /* */
};
template<typename TItem> container {
    /* some algorithms,that are std::enable_if selected,according to needs_thread_safety */
};

但是,我希望needs_thread_safety可以选择加入,而不需要定义(= default false_type).我试过以下:

struct thread_unsafe_item {
        /* */ 
    };

template<typename TItem>
struct thread_safety_selector
{
    template<typename T>
    struct has_defined_thread_safety
    {
        typedef char yes[1];
        typedef char no[2];

        template <typename C> static yes& test(typename C::needs_thread_safety*);
        template <typename> static no& test(...);

        static const bool value = sizeof(test<T>(0)) == sizeof(yes);
    };

    typedef 
        typename std::conditional<
            has_defined_thread_safety<TItem>::value,typename TItem::needs_thread_safety,std::false_type
        >::type needs_thread_safety;
};
....
struct <typename TItem> container {
    /* changed all TItem::needs_thread_safety selectors to thread_safety_selector<TItem>::needs_thread_safety */
};

但是显然没有延迟评估,因为错误是错误C2039:’needs_thread_safety’:不是’thread_unsafe_item’的成员.

如何为未指定的参数实现默认值?

它是出于教育目的,所以我不需要不同的方法来解决这个问题.

谢谢!

解决方法

你不能使用std :: conditional,因为它总是会解析它的所有参数.您可以创建自己的谓词:
template <bool,class>
struct get_thread_safety;

template <class T>
struct get_thread_safety<true,T>
{
  typedef typename T::needs_thread_safety type;
};

template <class T>
struct get_thread_safety<false,T>
{
  typedef std::false_type type;
};

// Used like this:

typedef 
    typename get_thread_safety<
        has_defined_thread_safety<TItem>::value,TItem
    >::type needs_thread_safety;

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读