场景中有2个物体:A,B

每一个物体上绑定2个脚本:A,B

初始化log:
Object : A , Script : B , Message : Awake
Object : A , Script : B , Message : OnEnable
Object : A , Script : A , Message : Awake
Object : A , Script : A , Message : OnEnable
Object : B , Script : B , Message : Awake
Object : B , Script : B , Message : OnEnable
Object : B , Script : A , Message : Awake
Object : B , Script : A , Message : OnEnable
Object : A , Script : B , Message : Start
Object : A , Script : A , Message : Start
Object : B , Script : B , Message : Start
Object : B , Script : A , Message : Start

特征:
1.每次Awake和OnEnable都是连续运行,最后才运行Start
2.物体运行顺序是依照字母升序排列。脚本顺序是依照字母降序排列
3.先运行完每一个物体上的全部脚本,再运行完下个物体上的全部脚本。以此类推。
相当于数据库的先group by obj ascending,group by script decending

销毁的log:
Object : A , Script : A , Message : OnDisable
Object : A , Script : B , Message : OnDisable
Object : A , Script : A , Message : OnDestroy
Object : A , Script : B , Message : OnDestroy
Object : B , Script : A , Message : OnDisable
Object : B , Script : B , Message : OnDisable
Object : B , Script : A , Message : OnDestroy
Object : B , Script : B , Message : OnDestroy
特征:
运行顺序:
1.依照唔拍拖的升序排列(ascending)
2.对于每一个物体上的脚本依照升序排列(ascending),这点是和初始化最大的不同点。
3.先运行完一个物体上的全部脚本的disable,再运行该物体上的全部脚本的destroy。然后轮到下一个物体。

掌握脚本生命周期直接决定脚本之间的调用顺序,否则非常可能出现NPE(null pointer exception)
在android 出现NPE还好,一旦iOS出现NPE。就会出现BAD_ACCESS,程序就挂掉了。这点Mono框架做的不是非常出色。


附:
AbstractMonoBehaviour.cs
using UnityEngine;

using System.Text;

public abstract class AbstractMonoBehaviour : MonoBehaviour 

{





    protected abstract bool EnableLog { get;}





void Start () 

       {

        Log("Start");

}

    void Awake()

    {

        Log("Awake");

    }





    void OnDestroy()

    {

        Log("OnDestroy");

    }





    void OnDisable()

    {

        Log("OnDisable");

    }





    void OnEnable()

    {

        Log("OnEnable");

    }



    





    protected void Log(object obj)

    {

        if (EnableLog)

        {

            StringBuilder sb = new StringBuilder();

            sb.Append("Object : ").Append(gameObject.name)

                .Append(" , Script : ").Append(GetType().Name)

                .Append(" , Message : ").Append(obj);

            Debug.Log(sb.ToString());

        }

    }





}

A.cs
using UnityEngine;

public class A : AbstractMonoBehaviour

{

    protected override bool EnableLog

    {

        get { return true; }

    }

}
B.cs
using UnityEngine;

public class B : AbstractMonoBehaviour

{

    protected override bool EnableLog

    {

        get { return true; }

    }

}

Unity3D脚本(MonoBehaviour)生命周期的更多相关文章

  1. Unity3d脚本的生命周期

    接下来,做出一下讲解:最先执行的方法是Awake,这是生命周期的开始,用于进行激活时的初始化代码,一般可以在这个地方将当前脚本禁用:this.enable=false,如果这样做了,则会直接跳转到On ...

  2. Unity3D 中 脚本(MonoBehaviour) 生命周期WaitForEndOfFrame需要注意的地方

    首先看看MonoBehaviour的生命周期 先上个图(来源 http://blog.csdn.net/qitian67/article/details/18516503): 1.Awake 和 St ...

  3. Unity3D脚本的生命周期(执行顺序)

    Unity脚本中有许多固定的函数 例如Start();Update(); 而这些函数都有固定的执行顺序 搞清楚这些函数的执行顺序 对于我们理清代码的逻辑就显得尤为重要 举个简单的例子 //脚本A pu ...

  4. MonoBehaviour生命周期

    MonoBehaviour生命周期 上图中重要的信息点很多,需要特别注意的是所有脚本的Awake方法都执行完才会执行Start,但是如果在Awake 中开启了一个协程这个协程中每一帧执行一些操作然后等 ...

  5. Unity脚本的生命周期中几个重要的方法

    1.function Update () {} 正常更新,用于更新逻辑.此方法每帧都会由系统自动调用一次.2.function LateUpdate () {} 推迟更新,此方法在Update() 方 ...

  6. Unity3D实践系列04, 脚本的生命周期

    Unity3D脚本生命周期是指从脚本的最初唤醒到脚本最终销毁的整个过程.生命周期的各个方法被封装到了MonoBehaviour类中.具体来说如下: 1.In Editor Mode 编辑模式 当在编辑 ...

  7. U3D C#脚本的生命周期

    MonoBehaviour是每个脚本的基类. 每个Javascript脚本自动继承MonoBehaviour,使用C#或Boo时,需要显式继承MonoBehaviour. 一开始实例化,直到结束实例被 ...

  8. 一张图彻底了解Unity脚本的生命周期

    以前没好好看Unity的脚本手册,原来写的是这么的全...尤其起yield  www  协同 这部分看了这张图彻底的懂了..

  9. Unity脚本的生命周期 同一脚本/不同脚本/游戏对象激没激活/脚本激没激活,几种情况下的Awake,OnEnable,Start的执行顺序

    可以自己在Unity里面试一下 游戏对象在Hierarchy面板不是激活的,它的脚本没作用,脚本中的函数不会执行; 游戏对象在Hierarchy面板是激活的,脚本没激活,Awake会执行,OnEnab ...

随机推荐

  1. python3之模块urllib

    urllib是python内置的HTTP请求库,无需安装即可使用,它包含了4个模块: request:它是最基本的http请求模块,用来模拟发送请求 error:异常处理模块,如果出现错误可以捕获这些 ...

  2. Space Replacement

    Write a method to replace all spaces in a string with %20. The string is given in a characters array ...

  3. arm GIC介绍之一【转】

    转自:https://blog.csdn.net/sunsissy/article/details/73791470 GIC是ARM架构中及其重要的部分,本文只在公开ARM对应资料基础上,以MTK开发 ...

  4. javaweb笔记四

    得到表单数据:1.String str = request.getParameter(String)//根据表单名得到表单值,如果是多个同名的键值,返回第一个值.2.String[] str= req ...

  5. Python+Selenium 自动化实现实例-定位frame中的元素

    场景 处理frame需要用到2个方法,分别是switch_to_frame(name_or_id_or_frame_element)和switch_to_default_content() 如何理解这 ...

  6. 003_Java笔记3:Eclipse添加jar包

    本文以jedis包为例,演示Eclipse如何添加和使用jar包.   1 建立一个名为ImportJarDemo的Java Project.在该工程下建立一个libs的文件夹. 2 将下载的jedi ...

  7. SqlServer导入Excel数据

    一:创建数据库: CREATE TABLE IndustrialTownTB ( [ID] [NVARCHAR](36) PRIMARY KEY NOT NULL , IndustrialNewCit ...

  8. Intellij Idea 使用时总是打开上次的项目

    Appearance&Behaviour-->>System Settings-->>Startup&Shutdown-->>Reopen last ...

  9. 使用Ocelot构建GateWay

    添加Nuget包:Ocelot 添加配置文件Ocelot.json 具体配置可以看另一篇Ocelot配置 Json配置文件主要包含两个根节点: ReRoutes:路由重定向配置 都是数组结构 可以配置 ...

  10. 如果django里的视图是类(CBV),应该如何写Url的测试用例?

    晚上回家测试了很多方式,都不行. 网上搜索找不到答案, 最后还是官方文档最抵用呢. https://docs.djangoproject.com/en/2.1/topics/testing/tools ...