未调用更具体的过载
More specific overload not called
本文关键字:调用 更新时间:2023-10-16
给定以下两个函数,如果我向第一个重载传递std::pair<const char*, std::size_t>
,我希望它会被调用,因为它比一般的T
更具体。
void foo(const std::pair<const char*, std::size_t>& p)
{
std::cout << "pair" << std::endl;
}
template <class T>
void foo(const T& v)
{
std::cout << "generic" << std::endl;
}
int main()
{
const char* s = "abc";
foo(std::make_pair(s, std::size_t(3)));
}
但是,该程序输出:
generic
为什么要调用第二个重载,而不是显式接受pair
的重载?
这是编译器的问题吗?我现在使用的是一个相当旧的编译器(GCC 4.1.2)。
嗯。。。这可能是编译器的问题:
http://ideone.com/97XwwZ
您的编译器肯定有错误。这是什么错误,只是猜测,但你是正确的,这段代码应该给出更具体的输出。样本不够大或不够复杂,任何更微妙的规则都不足以成为原因。
这似乎只是编译器的问题。我使用的是一个旧的编译器(GCC 4.1.2)。使用一个不那么古老的编译器似乎会导致正确的重载被称为
http://ideone.com/97XwwZ
#include <iostream>
#include <utility>
void foo(const std::pair<const char*, std::size_t>& p)
{
std::cout << "pair" << std::endl;
}
template <class T>
void foo(const T& v)
{
std::cout << "generic" << std::endl;
}
int main()
{
const char* s = "abc";
foo(std::make_pair(s, std::size_t(3)));
}
根据重载解决方案,它应该更喜欢示例中的特定解决方案。
我想说这是由于旧版本导致的编译器错误。当使用GCC 4.8.1进行编译时。输出
pair
根据这个链接:重载分辨率演示
相关文章:
- 什么时候调用组成单元对象的析构函数
- 对RValue对象调用的LValue ref限定成员函数
- 为什么使用 "this" 指针调用派生成员函数?
- 函数调用中参数的顺序重要吗
- OpenGL - 在抛出"__gnu_cxx::recursive_init_error"实例后终止调用?
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 为什么我的C#代码在调用回C++COM直到Task时会暂停.等待/线程.加入
- 在c++类上调用void函数
- 为什么 std::unique 不调用 std::sort?
- 调用专用模板时出错"no matching function for call to [...]"
- 选择要调用的构造函数
- C++为什么尽管我调用了void函数,它却不起作用
- 构造函数正在调用一个使用当前类类型的函数
- 变量没有改变?通过向量的函数调用
- 没有为自己的结构调用列表推回方法
- 调用'begin(int [n])'没有匹配函数
- 什么时候调用析构函数
- 如何用参数值调用函数(仅在运行时已知)
- std::cout.imbue()多重调用
- 函数何时会在c++中包含stack_Unwind_Resume调用