返回类型 T 的函数模板无法编译

发布于 2024-10-21 23:38:18 字数 811 浏览 8 评论 0原文

以下代码可以正常编译:

template<typename T>
void f(const T &item) { return; }

int main() 
{
  f("const string literal");
}

Compilation success at ideone : http://ideone.com/dR6iZ

但是当我提到返回类型,它无法编译:

template<typename T>
T f(const T &item) { return item; }

int main() 
{
  f("const string literal");
}

现在它给出错误:

prog.cpp:6: 错误:没有匹配的函数可用于调用“f(const char [21])”

ideone 处的代码: http ://ideone.com/b9aSb

即使我将返回类型设为const T,它也会无法编译

我的问题是:

  • 为什么它不能编译?
  • 返回类型与错误和函数模板实例化有什么关系?

The following code compiles fine:

template<typename T>
void f(const T &item) { return; }

int main() 
{
  f("const string literal");
}

Compilation succeeded at ideone : http://ideone.com/dR6iZ

But when I mention the return type, it doesn't compile:

template<typename T>
T f(const T &item) { return item; }

int main() 
{
  f("const string literal");
}

Now it gives error:

prog.cpp:6: error: no matching function for call to ‘f(const char [21])’

Code at ideone : http://ideone.com/b9aSb

Even if I make the return type const T, it doesn't compile.

My question is :

  • Why does it not compile?
  • What does the return type has to do with the error and the function template instantiation?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

姐不稀罕 2024-10-28 23:38:18

您无法从函数返回数组,因此模板实例化失败,并且没有匹配的函数。

您收到此特定错误是因为 SFINAE - 编译器无法实例化您的函数并不是真正的错误,这是一个没有匹配函数的错误。

可以返回对数组的引用 - 返回T const & 就可以了。

编辑:回应评论:

首先,这实际上是 SFINAE 的一个不错的例子。

template<typename T> T f(const T &item) { return item; }
char const * f(void const * item) { return 0; }
int main() {
  f("abc");
}

当编译器编译它时,它首先尝试实例化模板化的 f,为类型 const char [3] 创建完全匹配。由于上述原因,此操作失败了。然后,它会选择不精确匹配、普通函数,并在调用中将 const char [3] 衰减为 const char *

You cannot return an array from a function, so template instantiation fails, and there's no matching function.

You get this particular error because of SFINAE - It's not really an error that the compiler cannot instantiate your function, it is an error that there's no matching function.

You can return a reference to an array - returning T const & will work.

EDIT: In response to comments:

First, this is actually a decent example of SFINAE.

template<typename T> T f(const T &item) { return item; }
char const * f(void const * item) { return 0; }
int main() {
  f("abc");
}

When the compiler compiles this, it'll first try to instantiate the templated f, to create an exact match for the type const char [3]. This fails, because of the mentioned reasons. It'll then select the inexact match, the plain function, and in the call decay the const char [3] to a const char *.

梦过后 2024-10-28 23:38:18

看起来好像你告诉它你计划返回一个 T,但实际上你返回了一个 const T&。也许尝试将声明更改为:

template<typename T>
const T& f(const T& item) { return item; }

或者将返回值更改为参数的取消引用版本:

template<typename T>
T f(const T& item) { return (*item); }

it looks as though you tell it that you plan on returning a T, but then you actually return a const T&. maybe try changing the declaration to:

template<typename T>
const T& f(const T& item) { return item; }

or maybe change the return value to a dereferenced version of the argument:

template<typename T>
T f(const T& item) { return (*item); }
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文