看了引用计数之后  那时好像懂了   今天突然想起一个问题:

Scene也是继承自Ref 。然后也是静态生成一个autorelease后的对象  那计数就变成1了
class CC_DLL Scene : public Node
{
public:
    /** creates a new Scene object */
    static Scene *create();
{
Scene *Scene::create()
{
    Scene *ret = new Scene();
    if (ret && ret->init())
    {
        ret->autorelease();
        return ret;
    }
    else
    {
        CC_SAFE_DELETE(ret);
        return nullptr ;
    }
}
}
}

main函数里面: 【每种颜色代表一个函数  颜色嵌套代表函数的调用 类似栈】
int APIENTRY _tWinMain (HINSTANCE hInstance ,
                       HINSTANCE hPrevInstance ,
                       LPTSTR    lpCmdLine ,
                       int       nCmdShow)
{
    return Application::getInstance()->run();
          当中run(){
          while(!glview->windowShouldClose())
           {
             QueryPerformanceCounter(&nNow);
              if (nNow.QuadPart - nLast.QuadPart
> _animationInterval.QuadPart)
             {
                 nLast.QuadPart = nNow.QuadPart;
           
                 director->mainLoop();
                  当中mainLoop();
                    {
                       drawScene();
                       PoolManager::getInstance()->getCurrentPool()->clear();
                                        for (const auto &obj
: _managedObjectArray)
     {
        obj->release();
     }
                     }
                 glview->pollEvents();
             }
              else
             {
                 Sleep(0);
             }
         }
         }
}

我们看到蓝色代码那里,PoolManager::getInstance()->getCurrentPool()->clear();
这句代码会调用obj->release();把每一个增加autoreleasepool的对象进行release操作,好了问题就来了(不是挖掘面积)
Scene增加autorelease了  node继承的都增加了   Sprite也增加了  我们知道ref的构造函数是把引用计数自己主动变成1。那这里每一帧的绘画会把对象池里面的scene node sprite调用一次release 假设没有其它retain也就是变成0要回收了。可是不是这种,实际还是能够显示出来的
有两个地方  一个是scene的runWithScene一个是继承node的sprite这些等等

1、scene的runWithScene
【每种颜色代表一个函数  颜色嵌套代表函数的调用 类似栈】
bool AppDelegate ::applicationDidFinishLaunching() {
    auto director = Director::getInstance();
    auto glview = director->getOpenGLView();
    if(!glview) {
        glview = GLView::create("WeChat
Airplane" );
            glview->setFrameSize(600,800);
        director->setOpenGLView(glview);
    }
    director->setDisplayStats( true);
    director->setAnimationInterval(1.0 / 60);
    glview->setDesignResolutionSize(480, 800, ResolutionPolicy::SHOW_ALL );
    this->setResourceSearchResolution();
    auto scene = WelcomeScene::create();
    director->runWithScene(scene);
     runWithScene(scene){
          pushScene( scene);
          {
               _scenesStack.pushBack( scene);
               {
                    _data.push_back( object );
                    object ->retain();
               }
          }
     }
    return true;
}

从上面的代码  我们能够看到不妨retain了   所以scene是在mainloop里面的autoreleasepool减1  clear一次 可是他在_scenesStack retain了
那么就不会被回收了  那全部的node事实上都是加入到scene里面的。也就不会由于release Scene而导致node减1

2、继承node的sprite这些等等
我们知道都要addChild的  layer也好 node也好 sprite也好  都是要加进去的
void Node::addChild(Node *child)
{
    CCASSERT( child != nullptr , "Argument
must be non-nil" );
    this->addChild(child, child->_localZOrder, child->_tag);
     {
          void Node ::insertChild( Node* child, int z)
{
    _transformUpdated = true ;
    _reorderChildDirty =true;
    _children.pushBack(child);

     void pushBack(T object )
    {
        CCASSERT (object != nullptr , "The
object should not be nullptr" );
        _data.push_back( object );
        object ->retain();
    }
   child->_setLocalZOrder( z);
}
     }
}

从上面的调用来看  我们能够看到最后的调用还是用了object ->retain();
 所以mainloop里面autoreleasepool 调用release是把2变成1  然后autoreleasepool 已经把vector存的内容clear下一帧就不会调用了

【cocos2d-x-3.1.1系列5】cocos2d-x 引用计数细节的更多相关文章

  1. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(17)-注册用户功能的细节处理(各种验证)

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(17)-注册用户功能的细节处理(各种验证) ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)   (1):框 ...

  2. 【C++自我精讲】基础系列一 指针与引用

    [C++自我精讲]基础系列一 指针与引用   一 前言   指针.引用.指针与引用区别. 二 指针   变量:代码中常常通过定义变量来申请并命名存储空间,并通过变量的名字来使用这段存储空间. //变量 ...

  3. 【Cocos2d实例教程一】xcode5下Cocos2d环境的搭建

    (转载请注明出处:http://blog.csdn.net/buptgshengod) 第一步,现在要安装集成环境xcode5,安装xcode5需要系统至少是os x 10.8.5. 第二步,下载co ...

  4. 【58沈剑架构系列】RPC-client异步收发核心细节?

    第一章聊了[“为什么要进行服务化,服务化究竟解决什么问题”] 第二章聊了[“微服务的服务粒度选型”] 第三章聊了[“为什么说要搞定微服务架构,先搞定RPC框架?”] 上一章聊了[“微服务架构之RPC- ...

  5. Mybatis源码详解系列(四)--你不知道的Mybatis用法和细节

    简介 这是 Mybatis 系列博客的第四篇,我本来打算详细讲解 mybatis 的配置.映射器.动态 sql 等,但Mybatis官方中文文档对这部分内容的介绍已经足够详细了,有需要的可以直接参考. ...

  6. iOS内存管理系列之一:对象所有权与引用计数

    当一个所有者(owner,其本身可以是任何一个Objective-C对象)做了以下某个动作时,它拥有对一个对象的所有权(ownership): 1. 创建一个对象.包括使用任何名称中包含“alloc” ...

  7. webForm系列 前端框架快速引用

    Html的确定就是不能重用,MVC可以在_Layout.cshtml中将每个页面都需要的js和css文件(如jq,bootstrap等)都引用进去,webform就麻烦一点. webForm需要给所以 ...

  8. 学习React系列(六)——更新dom细节于原理

    React更新dom的依据: 1.不同类型的elements会产生不同的树 2.通过render方法中包含key属性的子元素,开发者可以示意哪些子元素可能是稳定的. 更新过程: 一.根元素类型不同:旧 ...

  9. Java系列:使用软引用构建敏感数据的缓存

    一.为什么需要使用软引用    首先,我们看一个雇员信息查询系统的实例.我们将使用一个Java语言实现的雇员信息查询系统查询存储在磁盘文件或者数据库中的雇员人事档案信息.作为一个用户,我们完全有可能需 ...

随机推荐

  1. springMVC接收get请求传递多个参数

    @RequestMapping(value = "/sendSignal/{state}/{limberId}/{account}", method = RequestMethod ...

  2. 《网络管理》IP地址管理与子网划分

    IP地址管理——ipmaster ipmaster是一款对IP地址进行管理的软件,使用该软件可以提高网络管理员的工作效率.在大型网络中,使用该软件可以有序且高效地实现大中小型企业网IP地址的分配和管理 ...

  3. 模块挂载、切换,uml模式、流程图模式

    模块挂载.切换,uml模式.流程图模式

  4. Exceptions & Errors - 异常与错误

    来源于 Ry’s Objective-C Tutorial - RyPress 一个学习Objective-C基础知识的网站. 个人觉得很棒,所以决定抽时间把章节翻译一下. 本人的英语水平有限,有让大 ...

  5. MFC_1.3 控件子类化 消息反射

    控件子类化 如果想要在默认的控件类中添加一些功能,就需要子类化一个控件类 在类内可以响应控件所有的消息,并且可以添加自己的函数和数据 通过类向导子类化控件的步骤 打开类向导,创建一个 MFC 类,不要 ...

  6. 【Linux】 JDK安装及配置 (linux-tar.gz版)

    安装环境:Linux(CentOS 7 64位 版) JDK安装:tar.gz为解压后就可以使用的版本,这里使用jdk-8u211-linux-x64.tar.gz版,安装到/usr/java/(us ...

  7. windows如何统计端口的连接数

    习惯了linux的系统管理员,对linux的命令行工具总是印象极深,几乎所有的管理都可以在命令行下完成.命令行工具是linux系统管理的主流. 而使用windows是,因为图形化的界面,大家习惯了图形 ...

  8. 梦想CAD控件 2018.7.26更新

    下载地址: http://www.mxdraw.com/ndetail_107.html 1.  增加属性匹配功能 2.  增加List命令 3.  增加CAD图纸审图批注功能 4.  环形阵列功能 ...

  9. 深入理解PHP之foreach

    招聘 标签(空格分隔): 招聘 PHP 国贸 语言基础 foreach 语法结构提供了遍历数组的简单方式. php5之前, foreach仅能用于数组php5+, 利用foreach可以遍历对象 fo ...

  10. Djang学习笔记-1

    1.django的生命周期: url匹配 -> 视图函数 -> 返回用户字符串 url匹配 -> 视图函数 -> 打开一个HTML文件,并读取内容2.创建Django proj ...