【发布时间】:2019-07-15 04:08:57
【问题描述】:
当这种奇怪的行为发生时,我正在处理一些代码:
在第一个测试中,基本模板函数、用户和模板特化位于同一个命名空间中,并且它的行为与我预期的一样:
namespace Test1
{
template <typename V, typename T>
int doFoo(V& a_visitor, T& a_value)
{
return 0;
}
struct Foo
{
template <typename T>
int process(T const& a_value)
{
return doFoo(*this, a_value);
}
};
template <typename T>
int doFoo(Foo& a_vis, T const& a_ptr)
{
return 1;
}
}
int main()
{
int const k{ 42 };
return Test1::Foo{}.process(k); // returns 1
}
但是当我将基本模板化函数及其特化移到另一个命名空间中时,会选择基本函数:
namespace Test2
{
namespace b
{
template <typename V, typename T>
int doBar(V& a_visitor, T& a_value)
{
return 0;
}
}
struct Bar
{
template <typename T>
int process(T const& a_value)
{
return b::doBar(*this, a_value);
}
};
namespace b
{
template <typename T>
int doBar(Bar& a_vis, T const& a_ptr)
{
return 1;
}
}
}
int main()
{
int const k{ 17 };
return Test2::Bar{}.process(k); // returns 0
}
编辑我可以做的更奇怪:在示例 1 中,如果我用 Test1::doFoo 替换对 doFoo 的调用,我会再次遇到错误的行为!
谁能解释一下这里发生了什么?如果我真的需要 struct Bar 不在命名空间 b 内,我该怎么办?
【问题讨论】:
标签: c++ templates namespaces template-specialization