首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >基于conditional_t的is_floating_point标签调度

基于conditional_t的is_floating_point标签调度
EN

Stack Overflow用户
提问于 2021-12-18 08:51:47
回答 1查看 84关注 0票数 0

对于一个简单的标记分派实现,我得到了一个奇怪的函数“等于”调用,它在模板定义中不可见,也不能通过依赖于参数的查找找到。

代码语言:javascript
复制
template <typename T>
bool Equals(T lhs, T rhs){
    return Equals(rhs, lhs, conditional_t<is_floating_point<T>::value, true_type, false_type>{});
}

template <typename T> // for floating
bool Equals(T lhs, T rhs, true_type){
    return abs(lhs - rhs) < 0.01;
}

template <typename T> // for all the other
bool Equals(T lhs, T rhs, false_type){
    return lhs == rhs;
}

我做错什么了?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-12-18 10:20:27

在执行标记分派时,您没有实例化true_type。但更重要的是,您需要更改函数的顺序,在执行分派的函数之前需要定义标记函数,例如:

代码语言:javascript
复制
template <typename T> // for floating
bool Equals(T lhs, T rhs, true_type){
    return abs(lhs - rhs) < 0.01;
}

template <typename T> // for all the other
bool Equals(T lhs, T rhs, false_type){
    return lhs == rhs;
}

// moved down here!
template <typename T>
bool Equals(T lhs, T rhs){
    return Equals(lhs, rhs, conditional_t<is_floating_point<T>::value, true_type{}, false_type>{});
}

尽管如此,在C++17和以后的版本中,您根本不需要使用标记分发,您可以使用if constexpr代替,例如:

代码语言:javascript
复制
template <typename T>
bool Equals(T lhs, T rhs){
    if constexpr (is_floating_point_v<T>)
        return abs(lhs - rhs) < 0.01;
    else
        return lhs == rhs;
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70402079

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档