对象缓冲池 ( cc.pool ) :

时间:2021-02-07 04:39:50

对象缓冲池 ( cc.pool ) :

作用 :

优化创建效率 , 尤其是针对需要多次创建的情况 .

缓冲池 API :

缓冲池 ( cc.pool ) 提供的函数并不多 , 只有5个 .

cc.pool.putInPool(obj);             //将对象放入缓冲池
cc.pool.hasObject(objClass); //判断缓冲池是否存在可用的指定对象
cc.pool.removeObject(obj); //删除指定对象
cc.pool.getFromPool(objClass); //从缓冲池获取指定对象
cc.pool.drainAllPools(); //清空缓冲池

用法 :

创建一个对象类 (Hero) , 添加两个函数 , unuse 和 reuse , 重点要注意的是 , unuse 里面的 retain 方法 , 没有的话 , 对象可能会被系统回收 .

var Hero = cc.Sprite.extend({
_hp:null,
_mp:null,
ctor: function(hp,mp){
this._super("res/box.png");
this.initData(hp,mp);
}, initData: function(hp,mp){
this._hp = hp;
this._mp = mp;
}, unuse: function(){
this._hp = 0; //属性清空
this._mp = 0;
this.retain(); //保存 防止被回收
this.removeFromParent();
}, reuse: function(hp,mp){
this.initData(hp,mp);
}
});

添加创建Hero 函数 .

var CreateHero = function(hp,mp){
if(cc.pool.hasObject(Hero)) //判断缓冲池里 是否存在 Hero对象
{
cc.log('取出');
return cc.pool.getFromPool(Hero,hp,mp); // 从缓冲池里取出 Hero对象
}
else
{
cc.log('新创建');
return new Hero(hp,mp)
}
};

先预先将5000个Hero对象放入缓冲池 , 然后我将连续创建5000个Hero的总耗时 和 预先将Hero放入缓冲池再取出5000个的总耗时做一个对比 .

var HelloWorldLayer = cc.Layer.extend({
ctor:function () {
this._super();
this.preparHeroPool(); //预先将5000个Hero放入缓冲池 this.create(1); //第一轮 从对象池取出5000个
this.create(2); //第二轮 新创建5000个
}, create: function(num){ var time = new Date().getTime(); for(var i = 0; i < 5000; i++)
{
var hero = CreateHero(1,2);
hero.setPosition(cc.winSize.width/2, cc.winSize.height/2);
this.addChild(hero);
} var totleTime = new Date().getTime() - time;
cc.log("第 "+num+" 轮总耗时 = ",totleTime);
}, preparHeroPool: function(){ for(var i = 0; i < 5000; i++)
{
var node = new Hero(0,0);
cc.pool.putInPool(node);
}
}, });

结果 :

对象缓冲池 ( cc.pool ) :

一次不能说明问题 , 再做一次测试 .

对象缓冲池 ( cc.pool ) :

从结果上来看 , 的确是存在性能差异的 .