#轉載段小程序

zhousqy 2006-12-01 10:59:31
#include <iostream>
#include <utility>
using namespace std;

template <typename ObjectType,
typename ReturnType,
typename MemFuncPtrType>
class PMFC {
public:
typedef std::pair<ObjectType*, MemFuncPtrType> CallInfo;

PMFC(const CallInfo& info) : callInfo(info) {}
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 *initVal) : ptr(initVal) {}

// no parameter
template <typename ReturnType>
const PMFC<T, ReturnType, ReturnType (T::*)()>
operator->*(ReturnType (T::*pmf)()) const {
return std::make_pair(ptr, pmf);
}

// one paramter
template <typename ReturnType, typename Param1Type>
const PMFC<T, ReturnType, ReturnType (T::*)(Param1Type)>
operator->*(ReturnType (T::*pmf)(Param1Type)) const {
return make_pair(ptr, pmf);
}

protected:
T *ptr;
};

template <typename T>
class SP : private SmartPtrBase<T> {
public:
SP(T *p) : SmartPtrBase<T>(p) {}

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

class Wombat {
public:
int dig() {
cout << "Digging..." << endl;
return 1;
}
int dig(int i) {
cout << "Digging " << i << " metres..." << endl;
}
int sleep() {
cout << "Sleeping..." << endl;
}
int sleep(int s) {
cout << "Sleeping " << s << " minutes..." << endl;
}
};

int main()
{
typedef int (Wombat::*PWMF)();
typedef int (Wombat::*PWMF1)(int);

SP<Wombat> pw = new Wombat;

PWMF pmf = &Wombat::dig;
(pw->*pmf)();

PWMF1 pmf1 = &Wombat::dig;
(pw->*pmf1)(5);

pmf = &Wombat::sleep;
(pw->*pmf)();

pmf1 = &Wombat::sleep;
(pw->*pmf1)(30);
}

//Implementing operator->* for Smart Pointers
//(Dr. Dobb's Journal October 1999/10)
//作者:Scott Meyers
...全文
142 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
zhousqy 2006-12-01
  • 打赏
  • 举报
回复
偶不會C嘎嘎滴:-)
taodm 2006-12-01
  • 打赏
  • 举报
回复
你要看了boost::shared_ptr才会汗!
scott meyers的My Most Important C++ Aha! Moments...Ever
Understanding how deleters work in Boost’s shared_ptr
要之
竟然可以在BASE没有virtual的析构函数时,shared_ptr<BASE> ptr(new DERIVED)能够正确地调DERIVED的析构函数。它甚至推荐把BASE的析构函数申明为protected以增强安全性。

64,637

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧