• cocos2d 缓存池 对象的再利用


    1.简单的叙述说明池


    例如,我们知道,游戏的游戏类型跑酷,游戏元素都在不断重复。游戏的内容将继续从屏幕右侧的创建,当元件在屏幕的左侧的,将消失。假设不变new 对象。release 对象 性能影响。怎样优化呢?就涉及到缓存池的概念。


    再举一个样例:一个主角在一个竞技场中不断杀怪。每次有5个怪出现,杀死一个又会出来一个。

    每次出怪就new 怪,死亡怪就release怪。会非常浪费的。

    已经死亡的怪,我们简单地给他补满血不就能够反复使用了嘛!像拍电影,一个人不是真正死亡,仅仅是看起来死了。还是能够反复使用的嘛!


    2.缓存池简单实现


    我们能够事先new10个怪放入到一个数组中。简单把这个数组称作缓存池,事实上就是一个数组。

    再搞个int的变量表示取数组中第几个怪,初始化为0,表示取第一个怪。

    1.当我们想要从屏幕中创建一个新怪时,不去new,而是用那个int变量从数组中取一个怪拿来用。当然拿来用之后,还要简单的初始化下,给他补满血啊。穿上完整衣服等等。再把int变量加1,假设int变量等于数组的长度时。把它归0。

    2.当一个怪被主角杀死时,让这怪播完死亡动画后,就remove掉,但不把他全然release掉。

    差点儿相同实现就是这样,简单吧!

    仅仅是注意初始缓存池。new对象的数量。一般要大于你实际使用的数量。


    3.简单代码


    //创建缓存池
    Vector bonePools;
    void createBonePools(){
        
        if(bonePools.empty()){
            for(int i = 0; i < 30; ++i){
                auto oneBone = Bone::create();
                bonePools.pushBack(oneBone);
            }
        }
    }

    //从缓存池中取一个对象
    int _boneIndex;
    Bone* getOneBone(){
        if(_boneIndex == bonePools.size()){
            _boneIndex = 0;
        }
        Bone* result = bonePools.at(_boneIndex);
         result->reuseInit();//这个比較重要,反复使用一个元素也要简单初始化一些东西的。之前死亡的人物记得给他补满血
        ++_boneIndex;
        return result;
    }


    cocos2d 缓存池 对象的再利用

    版权声明:本文博客原创文章,博客,未经同意,不得转载。

  • 相关阅读:
    压缩命令
    常用命令7-帮助命令1
    常用命令6--文件搜索命令4-grep
    常用命令5--文件搜索命令3-find
    常用命令4-文件搜索命令 2- which
    【转】Castle开发系列文章
    【摘录】C#多线程编程
    优化一
    Value Shadowing(不明確的方式存取变量)
    portability flaw : file separator (可移植性缺陷:文件分隔符)
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4638336.html
Copyright © 2020-2023  润新知