OOIII/

Unity脚本学习:MonoBehaviour类Invoke,Coroutine

MonoBehaviour概述

MonoBehaviour 表示一个单一的行为。Unity中用户对游戏对象的操作被分割成若干个单一行为。每个单一行为都作为一个MonoBehaviour类来封装。再生成每个MonoBehaviour类的实例,并作为组件嵌入游戏对象。然后按照一定的顺序(从下到上)调用每个对象的重载方法来实现游戏对象的全部行为。

创建

在菜单Assets->create中选择javascript活C# script创建一个脚本类。Unity规定:这些类都必须继承自MonoBehaviour。javascript 的脚本类自动继承MonoBehaviour,c#脚本类必须显式继承这个类。

特别之处

继承自MonoBehaviour的类,不需要自己创建它的实例,也不能自己创建(如 new 类名)。因为所有从MonoBehaviour继承过来的类,unity都会自动创建实例,并且调用被重载的方法,如我们经常用到的Awake,Start, Update等。而普通类,就可以用new来创建实例了。

异步函数

在一个方法执行时调用另一个方法。而被调用的方法或者其中的某些语句不是立刻执行,而是过一段时间后才执行。

MonoBehaviour提供了两种异步方法

  • 调用(Invoke)
  • 协程(Coroutine)

调用(Invoke)

function Invoke (methodName: string, time : float) : void function InvokeRepeating (methodName : string,time : float, repeatRate : float) : void function CancelInvoke () : void function IsInvoking (methodName: string) : bool

协程(Coroutine)

function StartCoroutine (routine: IEnumerator) : Coroutine function StartCoroutine (methodName: string, value : object = null) : Coroutine function StopCoroutine (methodName: string) : void function StopAllCoroutines () : void

协程介绍

协同程序与线程差不多,也就是一条执行序列,拥有自己独立的栈,局部变量和指令指针,同时又与其它协同程序共享全局变量和其它大部分东西。线程与协同程序的主要区别在于,一个具有多线程的程序可以同时运行几个线程,而协同程序却需要彼此协作地运行。就是说,一个具有多个协同程序的程序在任何时刻只能运行一 个协同程序,并且正在运行的协同程序只会在其显示地挂起时,它的执行才会暂停。

Unity中协程

一个协同程序在执行过程中,可以在任意位置使用yield语句。yield的返回值控制何时恢复协同程序向下执行。协同程序在对象自有帧执行过程中堪称优秀。协同程序在性能上没有更多的开销。StartCoroutine函数是立刻返回的,但是yield可以延迟结果。直到协同程序执行完毕。

function StartCoroutine (routine: IEnumerator) : Coroutine

参数表:IEnumerator

IEnumerator是枚举数接口。函数需要一个实现了这个接口的YieldInstruction对象。可以创建一个WaitForSeconds对象,在它的构造函数中传入挂起时间。

返回值:Coroutine

只用来表示一个协同程序实例的引用。没有任何暴露的变量和函数。一个coroutine是一个函数,它能在中断完成前挂起执行。

function StartCoroutine (methodName: string, value : object = null) : Coroutine

直接传入一函数名,开销大些。

比较

Invoke方法:执行没有被挂起,相当于设置完被调用函数的执行时间后即时向下执行。应用到没隔一段时间执行某个函数很方便。

Coroutine方法:新开一条执行序列(跟新建线程差不多)并挂起,等待中断指令结束。开销不大。当需要挂起当前执行时使用。比如Player死了一条命后消失,再过1.5秒后重新出现,就可以用将协同程序挂起。

gameObject.renderer.enabled= false; yieldWaitForSeconds(1.5f); gameObject.renderer.enabled= true;