如何将模板参数的函数传递改写成长尾形式?

2026-04-16 19:192阅读0评论SEO资讯
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计406个文字,预计阅读时间需要2分钟。

如何将模板参数的函数传递改写成长尾形式?

我将以下代码进行简化:

cppvoid A() { return 0; }void Test() { auto B2=Bint(&A)(); A();}int main() { Test();}

这段代码中,`A` 是一个返回整型的函数,`Test` 函数中创建了一个匿名函数 `B2`,它调用了 `Bint` 函数,并将 `A` 的地址作为参数传递。`main` 函数中调用了 `Test` 函数。但代码中缺少了 `Bint` 函数的定义。

我试图将一个函数作为参数传递给模板类 – 目标是然后我可以将任何函数作为参数传递并实现不同的功能:

int A() { return 0; } void Test() { auto B2 = B<int(*A)()>(&A); } int main() { Test(); }

但我正在收集编译问题:

如何将模板参数的函数传递改写成长尾形式?

$c++ -std=c++14 try.cpp try.cpp: In function 'void Test()': error: cast from 'int (*)()' to 'int' loses precision [-fpermissive] auto B2 = B<int(*A)()>(&A); ^ ^

如何使用任何返回类型的函数实例化B类并接受任何参数并解决编译?

您应该在自动B2 = …行中的模板参数中删除函数名称A,使其如下所示:

auto B2 = B<int(*)()>(A);

该名称不是类型说明符的一部分,并且类型是编译器在尝试实例化类模板时唯一查找的内容.您可以使用此代码段来引用函数的名称,并让编译器推断其类型:

auto B2 = B<decltype(&A)>(A);

请注意,您可以选择删除& A之前将它传递给B的构造函数(虽然不适用于decltype(& A)),因为它隐式转换为函数指针.

本文共计406个文字,预计阅读时间需要2分钟。

如何将模板参数的函数传递改写成长尾形式?

我将以下代码进行简化:

cppvoid A() { return 0; }void Test() { auto B2=Bint(&A)(); A();}int main() { Test();}

这段代码中,`A` 是一个返回整型的函数,`Test` 函数中创建了一个匿名函数 `B2`,它调用了 `Bint` 函数,并将 `A` 的地址作为参数传递。`main` 函数中调用了 `Test` 函数。但代码中缺少了 `Bint` 函数的定义。

我试图将一个函数作为参数传递给模板类 – 目标是然后我可以将任何函数作为参数传递并实现不同的功能:

int A() { return 0; } void Test() { auto B2 = B<int(*A)()>(&A); } int main() { Test(); }

但我正在收集编译问题:

如何将模板参数的函数传递改写成长尾形式?

$c++ -std=c++14 try.cpp try.cpp: In function 'void Test()': error: cast from 'int (*)()' to 'int' loses precision [-fpermissive] auto B2 = B<int(*A)()>(&A); ^ ^

如何使用任何返回类型的函数实例化B类并接受任何参数并解决编译?

您应该在自动B2 = …行中的模板参数中删除函数名称A,使其如下所示:

auto B2 = B<int(*)()>(A);

该名称不是类型说明符的一部分,并且类型是编译器在尝试实例化类模板时唯一查找的内容.您可以使用此代码段来引用函数的名称,并让编译器推断其类型:

auto B2 = B<decltype(&A)>(A);

请注意,您可以选择删除& A之前将它传递给B的构造函数(虽然不适用于decltype(& A)),因为它隐式转换为函数指针.