检查MSVC2012中声明的成员函数
Checking declared member function in MSVC2012
我编写了以下代码,它在GCC 4.7和MSVC 2013下按预期编译和工作,但在MSVC 2012下无法编译:
#include <iostream>
template<typename TClass>
struct IsLoadableHelper {
template<typename T, T t> struct Helper {};
struct Mixin1 {
void Load(std::istream*);
};
struct MixedStruct1 : public Mixin1, public TClass {};
// template<typename U>
// static char f(Helper<void(TClass::*)(std::istream*), &TClass::Load>*);
template<typename U>
static long f(Helper<void(Mixin1::*)(std::istream*), &U::Load>*);
template<typename U>
static char f(...);
enum { value = sizeof(f<MixedStruct1>(0)) == sizeof(char) };
};
struct Loadable
{
void Load(std::istream*);
};
struct DerivedLoadable : Loadable
{};
struct NotLoadable
{
};
int main(void)
{
std::cout << IsLoadableHelper<NotLoadable>::value << std::endl;
std::cout << IsLoadableHelper<Loadable>::value << std::endl;
std::cout << IsLoadableHelper<DerivedLoadable>::value << std::endl;
return 0;
}
#include "stdafx.h"
#include <iostream>
template<typename TClass>
struct IsLoadableHelper {
template<typename T, T t> struct Helper {};
struct Mixin1 {
void Load(std::istream*);
};
struct MixedStruct1 : public Mixin1, public TClass {};
template<typename U>
static long f(Helper<void(Mixin1::*)(std::istream*), &U::Load>*);
template<typename U>
static char f(...);
enum { value = sizeof(f<MixedStruct1>(0)) == sizeof(char) };
};
struct Loadable
{
void Load(std::istream*);
};
struct NotLoadable
{
};
int main(void)
{
std::cout << IsLoadableHelper<NotLoadable>::value << std::endl;
std::cout << IsLoadableHelper<Loadable>::value << std::endl;
return 0;
}
在 MSVC 2012 下编译期间,它返回以下错误:
1>Source.cpp(22): error C3867: 'IsLoadableHelper<TClass>::Mixin1::Load': function call missing argument list; use '&IsLoadableHelper<TClass>::Mixin1::Load' to create a pointer to member
1> with
1> [
1> TClass=Loadable
1> ]
1> Source.cpp(43) : see reference to class template instantiation 'IsLoadableHelper<TClass>' being compiled
1> with
1> [
1> TClass=Loadable
1> ]
1>Source.cpp(22): error C3867: 'IsLoadableHelper<TClass>::Mixin1::Load': function call missing argument list; use '&IsLoadableHelper<TClass>::Mixin1::Load' to create a pointer to member
1> with
1> [
1> TClass=DerivedLoadable
1> ]
1> Source.cpp(44) : see reference to class template instantiation 'IsLoadableHelper<TClass>' being compiled
1> with
1> [
1> TClass=DerivedLoadable
1> ]
我看到它无法解析指向 Load 函数的指针,并建议我获取指向基类的指针。这是意料之中的。但它报告了一个错误,而不是遵循 SFINAE 并继续,这是出乎意料的。我被限制只能使用 C++03,我需要使这段代码在 Visual Studio 2012 Update 4 下工作。如何修复?
更简单的替代方案怎么样:
template<typename TClass>
struct IsLoadableHelper {
template<typename T, T> struct Helper;
template<typename U>
static long f(Helper<void (U::*)(std::istream*), &U::Load>*);
template<typename U>
static char f(...);
enum { value = sizeof(f<TClass>(0)) == sizeof(char) };
};
这会满足MSVC2012吗?MSVC2013很开心!
相关文章:
- 对RValue对象调用的LValue ref限定成员函数
- 为什么使用 "this" 指针调用派生成员函数?
- 将公共但非静态的成员函数与ALGLIB集成
- 使用指向成员的指针将成员函数作为参数传递
- 将重载的成员函数传递给函数模板
- 我不小心调用了一个没有自己类对象的成员函数.但这是怎么回事呢
- 如何在C++中使用非静态成员函数作为回调函数
- C++错误C2600:无法定义编译器生成的特殊成员函数(必须首先在类中声明)
- 关联容器的下界复杂性:成员函数与非成员函数
- 在 C++ 中用派生类型重写成员函数
- 链表的泛型函数remove()与成员函数remove)
- 如何将lambda作为模板类的成员函数参数
- constexpr构造函数需要常量成员函数时出现问题
- 将自由函数绑定为类成员函数
- 区分非成员函数和头文件中的成员函数
- 如何从子成员函数修改父公共成员变量
- 保留对其他类的成员函数的引用
- 在运算符重载定义中使用成员函数(const错误)
- 内联如何影响模块接口中的成员函数
- 将成员函数指针作为参数传递给模板方法