在C++中通过模板规避潜在错误
2012-05-16 17:10:40 来源:WEB开发网核心提示:图2 定时器模块的实现使得在foo()和bar()函数中实例化回调函数类的方法需要注意一些点,否则容易犯错,在C++中通过模板规避潜在错误(3),在foo()函数所使用的方法中,如果不小心忘记了将类变量定义成静态的,且回调函数类和回调函数参数成为了两个模板类型,另一个变化是,会因为变量分配在栈上而最终导致程序出错;在b
图2
定时器模块的实现使得在foo()和bar()函数中实例化回调函数类的方法需要注意一些点,否则容易犯错。在foo()函数所使用的方法中,如果不小心忘记了将类变量定义成静态的,会因为变量分配在栈上而最终导致程序出错;在bar()函数中,如果忘记了将通过new分配获得的内存通过delete释放,则会产生内在泄漏。能否通过设计避免这些潜在的问题呢?
图3是对定时器管理模块采用模板重写后的程序。其中最大的变化是timer_t类的构造函数省去了指定回调函数类实例,且回调函数类和回调函数参数成为了两个模板类型。另一个变化是,fire()函数中通过定义静态变量的方式实例化回调函数类。
- template <typename T_CALLBACK, typename T_CALLBACK_ARG>
- class timer_callback_t
- {
- virtual void handle (timer_t <T_CALLBACK, T_CALLBACK_ARG> &_timer,
- T_CALLBACK_ARG _arg) = 0;
- };
- template <typename T_CALLBACK, typename T_CALLBACK_ARG>
- class timer_t
- {
- public:
- timer_t (msecond_t _duration, T_CALLBACK_ARG _callback_arg);
- private:
- void fire ()
- {
- static T_CALLBACK callback;
- callback.handle (*this, callback_arg_);
- }
- T_CALLBACK_ARG callback_arg_;
- };
更多精彩
赞助商链接