Scott Meyes 代码简单剖析完全修正版 2.0

王朝other·作者佚名  2006-11-24
宽屏版  字体: |||超大  

/*NOTE

请使用g++ 2.95 or higher, Intel C++ 5.0 or higher (6.0 has been released)

编译,其他主流编译器无法正确通过, VC 居然出现 26 处错误 */

#include < iostream >

#include < utility > //

含 pair 和 make_pairusing namespace std;

template <typename T>

struct MemFuncTraits { };

//partial specialization 1

template < typename R, typename O >

struct MemFuncTraits< R (O::*)() /*

指向成员函数指针 */ > { typedef R ReturnType;

typedef O ObjectType;

};

//partial specialization 2

template < typename R, typename O >

struct MemFuncTraits< R (O::*)() const /*

指向成员函数 const 的指针 */ > { typedef R ReturnType;

typedef O ObjectType;

};

//partial specialization 3

template < typename R, typename O, typename P1 >

struct MemFuncTraits< R (O::*)(P1) /*

指向具有参数类型的成员函数指针 */ > { typedef R ReturnType;

typedef O ObjectType;

};

//partial specialization 4

template < typename R, typename O, typename P1 >

struct MemFuncTraits< R (O::*)(P1) const /*

指向具有参数类型的 const 成员函数指针 */ > { typedef R ReturnType;

typedef O ObjectType;

};

template < typename MemFuncPtrType >

class PMFC {

public:

typedef typename MemFuncTraits<MemFuncPtrType>::ObjectType ObjectType;

typedef typename MemFuncTraits<MemFuncPtrType>::ReturnType ReturnType;

typedef std::pair<ObjectType*, MemFuncPtrType> CallInfo;

PMFC(const CallInfo& info) : _callinfo(info) { } //init

//

支持无参数类型,ReturnType = MemFuncPreType ReturnType operator()() const

{ return (_callinfo.first->*_callinfo.second)(); }

// 支持具有参数类型

template <typename Param1Type>

ReturnType operator()(Param1Type p1) const

{ return (_callinfo.first->*_callinfo.second)(p1); }

private:

CallInfo _callinfo;

};

template <typename T>

class SmartPtrBase {

public:

SmartPtrBase(T *p) : ptr(p) { } //init

//partial specialization PMFC

并 重载 operator->*. template <typename MemFuncPtrType>

const PMFC<MemFuncPtrType> operator->*(MemFuncPtrType pmf) const

{ return std::make_pair(ptr, pmf); }

private:

T* ptr;

};

template <typename T>

class SP : private SmartPtrBase<T> { // g++ 3.04

都有错误,改为 public,估计是一个 bug。Intel C++没有错误。public:

SP(T *p) : SmartPtrBase<T>(p) { }

using SmartPtrBase<T>::operator->*;

};

class Wombat {

public:

int dig() { cout << "Digging..." << endl; return 1; }

int sleep() { cout << "Sleeping..." << endl; return 5; }

int eat() const { cout << "Eatting..." << endl; return 7; }

int move(int op) { cout << "Moving..." << endl; return 9; }

};

typedef int (Wombat::*PWMF)();

typedef int (Wombat::*PWMFC)() const;

typedef int (Wombat::*PWMF1)(int);

main()

{

SP<Wombat> pw = new Wombat;

PWMF pmf = &Wombat::dig;

(pw->*pmf)(); // Digging...

pmf = &Wombat::sleep;

(pw->*pmf)(); // Sleeping...

PWMFC pmfc = &Wombat::eat;

(pw->*pmfc)(); // Eatting...

PWMF1 pmf1 = &Wombat::move;

(pw->*pmf1)(2); // Eatting...

return 0;

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有