模板(template)为C++带来了泛型编程的能力,但也带来了使用难度。大体上,使用模板的三大动机分别是提高复用性、去除强制转换和规避潜在错误。在此让我们看一看规避错误的一个例子。
假设我们有代码 1所示的被简化了的定时器管理模块程序。从构造函数来看,它的三个参数分别指明了定时器的延时时间、回调函数和回调函数的参数,其中的回调函数是通过timer_callback_t类加以封装的。当定时器到期时,它的fire()函数会被调用。间接地,fire()函数调用定时器所保存回调函数类对象的handle()函数。
class timer_callback_t
- {
- virtual void handle (timer_t &_timer, timer_callback_arg_t *_p_arg) = 0;
- };
-
- class timer_t
- {
- public:
- timer_t (msecond_t _duration, timer_callback_t *_p_callback,
- timer_callback_arg_t *_p_callback_arg);
-
- private:
- void fire ()
- {
- p_callback_.handle (this, p_callback_arg_);
- }
-
- timer_callback_t *p_callback_;
- timer_callback_arg_t *p_callback_arg_;
- };
|
代码1
代码 2示例了如何使用定时器。首先,得针对定时器的用途通过派生timer_callback_t类实现相应的回调函数类。接着,在创建定时器时需实例化回调函数类。代码中foo()和bar()函数分别示例了两种实例化回调函数类的方法,前者采用的是定义静态类变量,后者采用的是通过new进行动态分配。
- class connect_timeout_callback_t: public timer_callback_t
- {
- void handle (timer_t &_timer, timer_callback_arg_t *_p_arg)
- {
-
- }
- };
-
- void foo ()
- {
- static connect_timeout_callback_t callback;
- timer_t *p_timer = new timer_t (100, &callback, 0);
- }
-
- void bar ()
- {
- connect_timeout_callback_t *p_callback = new connect_timeout_callback_t ();
- timer_t *p_timer = new timer_t (100, p_callback, 0);
- }
|
代码2