多线程与单线程的自由切换一直是个有趣的话题。 开发人员喜欢在单线程下开发,准确有序不容易出错。 但是他们也舍不得放弃多线程带来的效率提升。 为了提升unity2d的性能限制。这里使用surparaller.org制作的pelagia。他可以在单线程和多线程之间自由切换。像开发其他的单线程软件一样使用pelagia。只要通过简单的设置就可以在单线程和多线程间自由切换。 最近骑马与砍杀的游戏非常流行。 让沙盒技术又受到了关注。 沙盒技术是指在游戏中玩家可以自由发展获得不同的游戏剧情。 最为有名的沙盒游戏还有P社的系列,其中包括维多利亚,钢铁雄心,欧陆风云等。 让沙盒游戏好玩的关键是创建大量的游戏角色。 例如骑马与砍杀每次都要创建上千个士兵。 创建大量游戏角色是对游戏引擎和游戏开发者的巨大挑战。 这种挑战来自2个方面。 第一, 使用恰当的技术,让游戏支持动态扩展。 第二, 将游戏分解到不同的线程,让系统资源使用最大化。 下面将用3个例子来说明如何进行操作。 第一个来自unity官方的示例roguelike.你可以在下面的地址找到它的介绍和代码. https://learn.unity.com/project/2d-roguelike-tutorial https://github.com/surparallel/unity_example_of_pelagia/tree/master/Roguelike 这个示例在性能方面有3个问题. 1,协程导致游戏阻塞。 2,不支持摄像头跟随。 3,碰撞检测会失败,导致npc的重叠。 所以针对上述3个问题我制作了Big Roguelike。 你可以在下面的链接找到它。 https://github.com/surparallel/unity_example_of_pelagia/tree/master/Big%20Roguelike Big Roguelikefe非常适合进行压力测试。我将地图扩大1千倍。并将npc数量设定到3000。 这样就达到了单线程下的极限。 为什么说单线程,因为只有一个线程处于满负荷的工作状态。 当你完成了第一个挑战之后,会发现再多的软件优化也无法大幅提升性能。 这时就要考虑更为激进的优化方案。 普通的技术水平是远远不能满足沙盒游戏的。 几个人甚至十几个人的战斗会让人昏昏欲睡。 为了解决一核有难多核围观的问题。我创建了示例Ultimate Roguelike。 你可以在下面的链接找到他。 https://github.com/surparallel/unity_example_of_pelagia/tree/master/Ultimate%20Roguelike Ultimate Roguelike在屏幕上可以创建9千个npc. 对unity压力也非常的小。 cpu的负载能力可以提升到60%。 将游戏分解到不同的线程,看着似乎非常简单。 但99%的游戏厂商都做不到。所以被玩家讥讽为单核游戏。 游戏设计者需要的是简单的技术就可以使游戏丰富多彩。 这样才能有余力设计更多复杂生动的剧情。 多线程优化有很多方案可以选择。从头学习多线程知识要花上好几年的时间。pelagia只需要你知道基本的异步消息概念就可以写出高质量的多线程软件。 如果unity是创建了一个世界,逻辑层级就是这个世界不同形式的镜像。unity是用颜色组成的世界,逻辑层是用其他数据组成的世界。通过异步消息将这些数据汇总起来就是在unity中看到的世界。pelagia根据使用数据的方式,读写或者逻辑依赖。将数据自动划分为不同的逻辑层,并为每个逻辑层配备消息路由,硬盘读写缓存等组件。这样就可以快速构建分层的世界。并把每个层放入不同的线程中。这与我们在实践中拆分软件系统所使用的方法是一样的。pelagia仅仅是将这个复杂的过程自动化了。
|