请教这个纯虚函数的实现有什么特别的意义吗

请问这个纯虚函数的实现有什么特别的意义吗
大概就像下面这个例子写的那样。。
test::run是作者遗留下来的垃圾吗

#include <stdio.h>

class test
{
public:
virtual void run() = 0;
virtual void prerun();
};

inline void test::run()
{
printf("test::fun()\n");
prerun();
}

void test::prerun()
{
run();

//some code here
}

class test_impl : public test
{
public:

virtual void run()
{
printf("test_impl::run()\n");
}
};

int main()
{
test *t = new test_impl();
t->prerun();
delete t;

return 0;
}



------解决方案--------------------
纯虚函数还给实现了?然后还相互调用。。。 垃圾代码无疑 
------解决方案--------------------
引用:
我他妈下午昏昏沉沉的用IDE在test的run和prerun来回跳转。。。
请教这个纯虚函数的实现有什么特别的意义吗
------解决方案--------------------
他这个纯虚函数的使用,类似于回调,你如果申明个回调可以达到一样的效果。
------解决方案--------------------
这种代码很常见的,只不过你这样实现纯虚函数肯定是不行的
子类只要实现run函数就可以了,不用关心其他细节
------解决方案--------------------
删掉代码看起来干净点
------解决方案--------------------

#include <stdio.h>
 
class test
{
public:
    virtual void run() = 0;
    /*virtual*/ void prerun(); //将virtual注释掉可能更清晰吧,也就是说不要覆盖prerun()
};

/*
我一直以为实现纯虚函数是不合法的,你竟然实现了还能正常编译,太不科学了 
inline void test::run()
{
    printf("test::fun()\n");
    prerun();
}
*/
 
void test::prerun()
{
    run(); //prerun()调用run,这个run因为是虚的,所以动态决定。
 
    //some code here
}
 
class test_impl : public test
{
public:
 
    virtual void run() //你这里实现了自己的run()
    {
        printf("test_impl::run()\n");
    }
};
 
int main()
{
    test *t = new test_impl();
    t->prerun();//这里t虽然是基类test指针,但内部其实调用 test_impl 中你实现的run函数
    //这样如果你有很多个继承test的子类test_implN,那么使用统一的代码t->prerun就能实现统一的功能。基本就是这用处。
    delete t;
 
    return 0;
}


我的理解都在注视中了。最后我感觉你俩函数名prerun和run是不是反了?
------解决方案--------------------
virtual void run() = 0;
纯虚函数,鉴定完毕