1
38
程序将启动循环,如果没有产量,它只在同一帧内运行所有迭代。 如果您有数百万次迭代,那么它很可能会阻止您的程序,直到所有迭代完成,然后继续。 创建协程时,Unity将其附加到单行为对象。它将在调用时首先运行startcroutine,直到达到产量。然后,它将从协程返回,并基于产量将其放置到堆栈上。如果生成null,则它将在下一帧再次运行。有许多不同的YieldInstruction可以从协程返回,您可以阅读更多关于它们的信息 here and through the related links . 一旦协程已经产生,主线程将继续运行。在下一帧中,Unity将找到堆叠的协程,并从他们在屈服时停止的位置调用它们。 如果您的协程从未超出范围,那么您基本上创建了一个更新方法。 协程的目的是在不阻塞程序的情况下执行可以跨越一段时间的操作。 重要事实:这不是多线程。 |
2
10
你说得对。
“为什么这是必要的”可能是因为您希望对象每帧移动一个输入。没有
更重要的是:看起来你想
|
Ahmed Elbohoty · Python为什么我在这里没有输出 7 年前 |
Aaron_ab · python-yield(yield)做什么? 7 年前 |
Chancelot · 块执行的测试ruby屈服方法 7 年前 |
georg · 从阵列创建的生成器列表中生成 7 年前 |
TinyTheBrontosaurus · 如何在产量中扩展元组? 7 年前 |
Eric Burel · 按顺序运行一系列sagas效果 7 年前 |
geostocker · C#[重复]中的产量理解困难 7 年前 |