微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

为什么 decltype 不实例化这个递归函数原型?

如何解决为什么 decltype 不实例化这个递归函数原型?

我创建了以下代码来创建从 0 到 N 的数字序列。我知道有像 here 这样的 O(log N) 实例化深度更好的方法,但这不是重点。

#include <cstddef>

template<std::size_t... Ns> struct hasNums;

template<bool> struct hasBool;

template<std::size_t... Ns> 
hasNums<Ns...>* makeNums(hasBool<false>*);

template<std::size_t First,std::size_t... Ns> 
constexpr
decltype(makeNums<(First - 1),First,Ns...>(
static_cast<hasBool<static_cast<bool>(First - 1)>*>(0)
) ) makeNums(hasBool<true>*);

template<std::size_t... Ns>
void method(hasNums<Ns...>*){

}

int main()
{
    method(static_cast<decltype(makeNums<20>(static_cast<hasBool<true>*>(0)))>(0)) ;
  
}

Link to the code in cppinsights

在 cppinsights 上运行代码显示只有 method 被实例化,这只是为了我可以看到数字 0 到 N 确实正在生成。我很惊讶,因为我以为我也会看到 makeNums 的实例化。编译器如何在没有其他实例化的情况下创建这个索引序列?

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。