看下面的输出就知道,其实就是定义了一个Delegate<void(int,int)>:
1>c:\documents and settings\administrator\my documents\visual studio 2005\projects\delegate\delegate\call.h(74) : error C2752: 'Delegate<T>' : more than one partial specialization matches the template argument list
1> with
1> [
1> T=void (int,int)
1> ]
1> c:\documents and settings\administrator\my documents\visual studio 2005\projects\delegate\delegate\delegate.h(564): could be 'Delegate<void(A,B)>'
1> c:\documents and settings\administrator\my documents\visual studio 2005\projects\delegate\delegate\delegate.h(530): or 'Delegate<Ret(A,B)>'
后来想试试直接定义一个Delegate<void(int,int)> test对象看看,结果整个都可以编译了,运行也正常。把这行定义放到main和全局效果都一样,删了它却又会出上面的错误,真是奇怪,定义一个对象,竟然解决了决议问题。
定义的地方,大致像下面这样:
template <typename T>
struct ClassA
{
};
template <typename Ret, typename A, typename B>
struct ClassA <Ret(A, B)>
{
};
template <typename A, typename B>
struct ClassA <void(A, B)>
{
};
template <typename T>
struct ClassB
{
};
template <typename Ret, typename A>
struct ClassB <Ret(A)>
{
ClassA<void(Ret,A)> a;
};
上面这个是可以编译的。但我那个程序在类似的情况下,却出现无法决议。这个问题在前面编写Delegate类时出现过,我简单地增加了一个模板参数,把函数类型参数的返回值作为另一个模板参数,解决了这个问题。
在G++下编译,一切正常。
VC2005 Beta 2,这个BUG得改改。。。不知道在哪可以提交?
1>c:\documents and settings\administrator\my documents\visual studio 2005\projects\delegate\delegate\call.h(74) : error C2752: 'Delegate<T>' : more than one partial specialization matches the template argument list
1> with
1> [
1> T=void (int,int)
1> ]
1> c:\documents and settings\administrator\my documents\visual studio 2005\projects\delegate\delegate\delegate.h(564): could be 'Delegate<void(A,B)>'
1> c:\documents and settings\administrator\my documents\visual studio 2005\projects\delegate\delegate\delegate.h(530): or 'Delegate<Ret(A,B)>'
后来想试试直接定义一个Delegate<void(int,int)> test对象看看,结果整个都可以编译了,运行也正常。把这行定义放到main和全局效果都一样,删了它却又会出上面的错误,真是奇怪,定义一个对象,竟然解决了决议问题。
定义的地方,大致像下面这样:
template <typename T>
struct ClassA
{
};
template <typename Ret, typename A, typename B>
struct ClassA <Ret(A, B)>
{
};
template <typename A, typename B>
struct ClassA <void(A, B)>
{
};
template <typename T>
struct ClassB
{
};
template <typename Ret, typename A>
struct ClassB <Ret(A)>
{
ClassA<void(Ret,A)> a;
};
上面这个是可以编译的。但我那个程序在类似的情况下,却出现无法决议。这个问题在前面编写Delegate类时出现过,我简单地增加了一个模板参数,把函数类型参数的返回值作为另一个模板参数,解决了这个问题。
在G++下编译,一切正常。
VC2005 Beta 2,这个BUG得改改。。。不知道在哪可以提交?