POCO C++库学习和分析 -- 内存管理 (三) 看完Poco 库中的智能指针,基本上Poco 中的内存管理已经快结束了。其他的部分都是些边边角角的东西,非常的简单。下面一一介绍。 4. Au toReleasePool AutoReleasePool 类的出现也同样是为了解决用户动态分配对象的释放问题,但同智能指针AutoPtr 和SharedPtr 通过把堆上的对象包装成栈对象,再通过引用计数在类的析构函数中实现自动删除对象的解决方案不同是,其策略为构造一个容器,用来存储动态对象的指针,在 AutoReleasePool 析构函数中统一释放。 这个过程和java 语言中的垃圾收集机制是类似的,只不过 AutoReleasePool 实现的非常简单,在AutoReleasePool 销毁时释放资源,而在 java 语言中会连续不断的定时检查并释放闲置资源。当然为了实现这个过程,AutoReleasePool 对所释放的类是有要求的,释放的类必须实现 release()接口。下面通过一个例子来说明问题: [cpp] view plaincopy 1. #include "Poco/AutoReleasePool.h" 2. using Poco::AutoReleasePool; 3. class C 4. { 5. public: 6. C() 7. {} 8. void release() 9. { 10. delete this; 11. } 12. }; 13. 14. int main(int argc, char** argv) 15. { 16. AutoReleasePool pool; 17. C* pC = new C; 18. pool.add(pC); 19. pC = new C; 20. pool.add(pC); 21. return 0; 22. } 23. // all C's deleted 其类图如下: 在图中可以看出,AutoReleasePool 实际上就是原生指针的一个容器,在其内部定义为: [cpp] view plaincopy 1. std::list ObjectList _list 需要注意的是,如果同时使用AutoReleasePool 和AutoPtr 对指针进行管理时,应该如此实现: [cpp] view plaincopy 1. AutoReleasePool arp; 2. AutoPtr ptr = new C; 3. ... 4. arp.add(ptr.duplicate()); 很明显此刻AutoReleasePool 和AutoPtr 对对象应该共享所有权。 5. 动态工厂模板(Dy namicFactory Class Template) Poco 中实现了一个动态工厂的模板,支持通过类名来创建类。其实现技术和前面的文章"Foundation 库SharedLibrary 模块分析"中介绍的类似。 动态工厂类 DynamicFactory 是抽象工厂类 AbstractFactory 的容器。 [cpp] view plaincopy 1. template 2. class DynamicFactory 3. ///...