using UnityEngine;
using System.Collections;
using System.Text; public class rotCube : MonoBehaviour { //示例,如何为一个自定义对象实现GetEnumerator接口,从而可以对该对象使用foreach
//这种写法是c#2.0才有的,通过yield关键字与IEnumerator返回类型组合成一个枚举器
//C#会自动生成一个IEnumerator类,该类实现了MoveNext(),Reset(),Current
//在C#2.0之前,我们必须自己来写一个IEnumerator类,才实现上面的接口与属性
class MyCalc : IEnumerable{
int rest = ;
public int x = ;
public int y = ; public IEnumerator GetEnumerator ()
{
for(int i=; i<y; ++i)
{
yield return rest = x * rest;
}
}
} //示例,如何将一个函数写成可以被枚举的对象(拥有MoveNext(),Reset(),Current)
//C#会自动生成一个IEnumerator类,该类实现了MoveNext(),Reset(),Current
//在C#2.0之前,我们必须自己来写一个IEnumerator类,才实现上面的接口与属性
IEnumerable calc(int x, int y){
int rest = ;
for(int i=; i<y; ++i)
{
yield return rest = x * rest;
}
} IEnumerator waitprint(){//协程返回类型必须为IEnumerator,它不认IEnumerable,如yield return DoCheck (),若DoCheck为IEnumerable,则DoCheck不会被执行 //StartCoroutine("DoCheck");//启动一个新的协程
//yield return DoCheck (); //在这里进入死循环,若改为StartCoroutine("DoCheck");则不会进入死循环,只会另外启动一个协程 yield return new WaitForSeconds (); //暂停5秒,若流程走到了这里,协程将在这里阻塞5秒才执行下面的代码
yield return new GameObject ();
yield return ;
}
IEnumerable waitPrint(){
yield return ;
yield return ;
} IEnumerator DoCheck(){
for(;;){
Debug.Log ("doecheck");
//协程调用频率最高是每帧一次,这里我们指定的等待时间小于一帧,并不能达到一帧调用多次docheck的效果
yield return new WaitForSeconds (0.0001f); //0.1毫秒,1/0.0001F = 10000 fps,显然U3D不可能达到这个帧率
}
} void Start () { /************************************************************************/
/* 自定义对象的枚举测试,自定义方法的枚举测试,这是理解协程的基础 */
/************************************************************************/
StringBuilder sbd = new StringBuilder();
foreach(var n in calc (, )){
sbd.Append (n);
sbd.Append (",");
} sbd.Length = ;
MyCalc omc = new MyCalc (){ x = , y = };
foreach(var n in omc){
sbd.Append (n);
sbd.Append ((","));
} /************************************************************************/
/* 协程综合测试 */
/************************************************************************/
//U3D协程特征:本质是一个返回值为IEnumerator的函数,函数中至少有一条yield return语句。
//协程必须由StartCoroutine来启动
//协程并非线程,线程是操作系统层的东西,协程是引擎层面由逻辑调用来实现的,是由一个线程操作出来的,在LUA中是由LUA状态机实现,在U3D是由U3D引擎状态机实现。
//在U3D中,协程是U3D引擎在每帧的update之后调用一次协程函数来实现,在update()中写一个死循环,会发现程序卡死,协程也不会执行了。这证明了协程和主线程是同一线程。
//UNITY手册的Execution Order of Event Functions一节详细讲解了协程的调用时机,从中可以看出协程只是主线程中的逻辑调用,并非一个新线程。 //StartCoroutine ("DoCheck");
//yield return waitprint (); //waitprint被完整执行
//yield return waitPrint (); //waitPrint没有被执行,U3D不认这种形式 //协程返回类型必须为IEnumerable。
//但不管一个函数的返回类型是IEnumerable还是IEnumerator,只要函数体中有一句yield return,编译器就会自动为该函数生成一个IEnumerator类型的对象。
//就可以使用此迭代器对象的MoveNext(), Current等方法,属性。若是返回类型为IEnumerable,编译器还会生成GetEnumerator()方法。
waitprint ();//直接调用协程函数无效,不会进入该函数执行,这时仅相当于返回了一个IEnumerator迭代子的临时对象,并没有执行具体代码。 //只有如下调用,才会完整的执行协程函数
IEnumerator i = waitprint ();
i.MoveNext (); //从函数入口执行到yield return new WaitForSeconds (5);
i.MoveNext (); //从上一个yield语句末执行到yield return new GameObject ();
i.MoveNext (); //从上一个yield语句末yield return 2;
//下面这种写法并不能达到上面的效果,原因是每次waitprint ()返回的是一个不同的临时对象,通过gethashcode可以发现。
//waitprint ().MoveNext ();
//waitprint ().MoveNext ();
//waitprint ().MoveNext (); //返回值为IEnumerable类型的示例
//只有返回值为IEnumerable的方法才能用于foreach,因为它要求实现GetEnumerator
i = waitPrint ().GetEnumerator ();
i.MoveNext ();
i.MoveNext ();
i.MoveNext (); print ("done");
} void Update(){
transform.Rotate (, , );
}
}

Unity 协程Coroutine综合测试的更多相关文章

  1. Unity协程(Coroutine)管理类——TaskManager工具分享

    博客分类: Unity3D插件学习,工具分享 源码分析   Unity协程(Coroutine)管理类——TaskManager工具分享 By D.S.Qiu 尊重他人的劳动,支持原创,转载请注明出处 ...

  2. Unity协程Coroutine使用总结和一些坑

    原文摘自 Unity协程Coroutine使用总结和一些坑 MonoBehavior关于协程提供了下面几个接口: 可以使用函数或者函数名字符串来启动一个协程,同时可以用函数,函数名字符串,和Corou ...

  3. unity协程coroutine浅析

    转载请标明出处:http://www.cnblogs.com/zblade/ 一.序言 在unity的游戏开发中,对于异步操作,有一个避免不了的操作: 协程,以前一直理解的懵懵懂懂,最近认真充电了一下 ...

  4. Unity 协程(Coroutine)原理与用法详解

    前言: 协程在Unity中是一个很重要的概念,我们知道,在使用Unity进行游戏开发时,一般(注意是一般)不考虑多线程,那么如何处理一些在主任务之外的需求呢,Unity给我们提供了协程这种方式 为啥在 ...

  5. Unity协程(Coroutine)原理深入剖析

    Unity协程(Coroutine)原理深入剖析 By D.S.Qiu 尊重他人的劳动,支持原创,转载请注明出处:http.dsqiu.iteye.com 其实协程并没有那么复杂,网上很多地方都说是多 ...

  6. Unity协程(Coroutine)原理深入剖析(转载)

    记得去年6月份刚开始实习的时候,当时要我写网络层的结构,用到了协程,当时有点懵,完全不知道Unity协程的执行机制是怎么样的,只是知道函数的返回值是IEnumerator类型,函数中使用yield r ...

  7. Unity协程(Coroutine)原理深入剖析再续

    Unity协程(Coroutine)原理深入剖析再续 By D.S.Qiu 尊重他人的劳动,支持原创,转载请注明出处:http.dsqiu.iteye.com 前面已经介绍过对协程(Coroutine ...

  8. 【转】Unity协程(Coroutine)原理深入剖析

    Unity协程(Coroutine)原理深入剖析 By D.S.Qiu 尊重他人的劳动,支持原创,转载请注明出处:http.dsqiu.iteye.com 记得去年6月份刚开始实习的时候,当时要我写网 ...

  9. Unity怎样在Editor下运行协程(coroutine)

    在处理Unity5新的AssetBundle的时候,我有一个需求,须要在Editor下(比方一个menuitem的处理函数中,游戏没有执行.也没有MonoBehaviour)载入AssetBundle ...

随机推荐

  1. iOS仿京东分类菜单实例实现

    在APP开发过程中此功能还是比较常见的模块,左边为菜单展示,右边为菜单下数据的展示,选择不同的菜单右边的数据源进行更新,此实例主要运用到UITableView,UICollectionView,OC谓 ...

  2. iOS设计模式之中介者模式

    中介者模式 基本理解 中介者模式又叫做调停者模式,其实就是中间人或者调停者的意思. 尽管将一个系统分割成许多对象通常可以增加可复用性,但是对象之间的连接又降低了可复用性. 如果两个类不必彼此直接通信, ...

  3. 【读书笔记】iOS-UIFont-如何知道字体的PostScript名称

    一,名词解释 PostScript字体: 按 PostScript 页面描述语言 (PDL) 规则定义的字体,并且只能在 PostScript 兼容的打印机上打印. 二,打开Launchpad---- ...

  4. 写给IOS开发工程师的网页前端入门笔记

    前言:作为IOS开发工程师,终会接触到网页前端开发,甚至可能会有 用HTML5开发IOS的app客户端的需求.比如现在上架的app就有比如理财类型的app有的就用HTML开发的,从理财类型的app需求 ...

  5. IOS之UI--自定义按钮实现代理监听点击事件

    前言: Objective-C提供的按钮监听事件的方法是 不含参数的监听方法 [button实例对象 addTarget:self action:@selector(func) forControlE ...

  6. Effective Java 20 Prefer class hierarchies to tagged classes

    Disadvantage of tagged classes 1. Verbose (each instance has unnecessary irrelevant fields). 2. Erro ...

  7. 【php】使用phpdbg来调试php程序

    PHPDBG是一个PHP的SAPI模块,可以在不用修改代码和不影响性能的情况下控制PHP的运行环境 可以在PHP5.4和之上版本中使用.在PHP5.6和之上版本将内部集成 功能 单步调试 灵活的下断点 ...

  8. Mysql的float类型造成的困扰总结

    因为换了工作正在学习使用MySQL,今天领导提出了一个问题,如下: X列是累加值,A列是每日新增值,那么X2应该是X1+A2,而且存储过程里也是这样计算的.可是奇怪的是X2的值却总是和正确值(2396 ...

  9. FQ 也要使用 Telegram

    不知怎么回事,一款优秀的开源,跨平台,安全的即时通讯工具 Telegram 就被 GG 了. 但是我们还得继续使用--那就 FQ 吧.用 ShadowSocks FQ 还不错. 安装 ShadowSo ...

  10. AFHTTPClient的异步回调模式

    以前第一个版本,ios的http都用的同步模式,在很多地方会导致线程阻塞,自己开发了一个简易的AFHTTPClient的异步回调模式. 回调的protocol: @protocol MyAFNetwo ...