内容简介:对象池机制:可回收与重复使用手机游戏的性能对于一款手机游戏来说,那是相当的重要了,我们常说的性能呢,一般包括耗电,发热情况,流畅度,是否存在卡帧等等。从专业的角度来说,包括FPS帧数,手速侦测,CPU和内存占用率等等。那我们今天就来说一下如何通过使用对象池的机制,有效的提高内存和计算效率,从而达到提高游戏流畅度的目的。
cocos2dx游戏性能优化之对象池
对象池机制:可回收与重复使用
手机游戏的性能对于一款手机游戏来说,那是相当的重要了,我们常说的性能呢,一般包括耗电,发热情况,流畅度,是否存在卡帧等等。从专业的角度来说,包括FPS帧数,手速侦测,CPU和内存占用率等等。那我们今天就来说一下如何通过使用对象池的机制,有效的提高内存和计算效率,从而达到提高游戏流畅度的目的。
其本质与缓存类似,即希望能减少那些频繁使用的对象的重复创建和销毁,例如飞行射击类游戏中的子弹。使用对象池机制能带来两方面的收益,首先是减少对象初始化阶段的重复计算,其次是避免反复地向操作系统申请归还内存。一个很好的例子就是捕鱼游戏中的鱼,鱼和鱼之间的属性是类似的,不一样的仅仅是当前的坐标位置及正在播放的动画帧。那么,当鱼游出屏幕后,可以不对其进行销毁,而是暂存起来。某一时刻需要重新创建鱼时,我们可以将其从对象池中取出,重新申请内存并初始化,这样就大大减轻了 CPU 的负担。
一个高效实现的对象池还要考虑如何有效地处理对象的生成和归还,以及占用内存的动态增长等问题。
代码实现如下:
/*
** obejct pool template for create or destroy object
** by hnliu
** 2016.9.19
**/
#include "Singleton.h"
#include "Bullet.h"
template<class T>
class ObjectPool :public Singleton<ObjectPool<T>>
{
public:
ObjectPool()
{
for (int i = 0; i < INITALCAPACITY; ++i)
{
auto pObj = new T();
pObj->autorelease();
pObj->retain();
objects.push_back(pObj);
}
}
~ObjectPool()
{
for (auto iter = objects.begin(); iter != objects.end(); iter++)
{
(*iter)->release();
}
objects.clear();
}
//get a bullet
T* getObject()
{
if (objects.empty())
{
for (int i = 0; i < INITALCAPACITY; ++i)
{
auto pObj = new T();
pObj->autorelease();
pObj->retain();
objects.push_back(pObj);
}
}
auto obj = objects.back();
objects.pop_back();
return obj;
}
void freeObject(T *obj)
{
//recycle part of pool
if (objects.size() >= (1.5 * INITALCAPACITY))
{
for (int i = 0; i < INITALCAPACITY / 2; ++i)
{
auto obj = objects.back();
obj->release();
objects.pop_back();
}
}
obj->reset();
objects.push_back(obj);
}
private:
std::list<T*> objects;
const int INITALCAPACITY = 256;
};
首先这是一个模板类,可以针对一切cocos2d::Ref的子类,使用起来也很方便,就是在初始话的地方ObjectPool::newInstance(),这样可以初始话一个鱼的对象池,对象池的构造函数中会初始化256个对象,不要忘记调用retain否则会在一帧结束后自动释放。
ObjectPool()
{
for (int i = 0; i < INITALCAPACITY; ++i)
{
auto pObj = new T();
pObj->autorelease();
pObj->retain();
objects.push_back(pObj);
}
}
getObject方法可以从对象池里拿一个对象,然后,再使用结束了以后要使用freeObject归还对象。
T* getObject()
{
if (objects.empty())
{
for (int i = 0; i < INITALCAPACITY; ++i)
{
auto pObj = new T();
pObj->autorelease();
pObj->retain();
objects.push_back(pObj);
}
}
auto obj = objects.back();
objects.pop_back();
return obj;
}
getObject方法,首先会判断对象池里还有没有对象了,如果发现没有了,就一次性创建256个对象,待使用,然后freeObject的时候,也会判断对象池里如果有充裕的对象,就会释放一部分对象。
void freeObject(T *obj)
{
//recycle part of pool
if (objects.size() >= (1.5 * INITALCAPACITY))
{
for (int i = 0; i < INITALCAPACITY / 2; ++i)
{
auto obj = objects.back();
obj->release();
objects.pop_back();
}
}
obj->reset();
objects.push_back(obj);
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 【提供源码包】高性能存储对象缓存 之【Memcached】
- java对象头信息和三种锁的性能对比
- 使用minio搭建高性能对象存储-第一部分:原型
- 在CentOS7上部署Memcached高性能内存缓存对象
- 理解高性能内存缓存对象缓存Memcached原理 (Memcached核心概念,部署)
- 在LAMP架构中安装Memcached高性能内存对象缓存应用(内含所有源码包)
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
常用算法深入学习实录
张子言 / 电子工业出版社 / 2013-10 / 89.00元
对于任何一门编程语言来说,算法都是程序的“灵魂”。正是因为算法如此重要,所以笔者精心编写了本书,希望通过书中的内容引领广大读者一起探讨学习算法的奥秘,带领广大读者真正步入程序开发的高级世界。 本书共分15章,循序渐进、由浅入深地详细讲解算法的核心内容,并通过具体实例的实现过程演练各个知识点的具体用法。本书首先详细讲解算法的基础知识,剖析了将算法称为“程序灵魂”的原因。然后详细讲解算法技术的核......一起来看看 《常用算法深入学习实录》 这本书的介绍吧!