You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

111 lines
12 KiB
Markdown

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

# 课后阅读 | 游戏开发工程师学习路径(上)
整个开发流程和内容我已经讲完了。你现在已经不是一个完全零基础的小白了。作为一个满心想要进入游戏开发行业的人,或者想要在游戏行业深耕,你可能要问了,后续的路,该怎么走呢?今天,我就来和你聊一聊这个内容。
我会通过这份看似很长的必读书单,先给你搭建一个学习路径,然后从底层知识和游戏开发这两方面分别讲讲,想成为游戏开发工程师,应该掌握哪些知识。
我在专栏里讲了很多具体的操作,作为初学者,把这些彻底掌握,其实已经差不多了。但是想要进阶,成为一名真正的游戏开发工程师,你还有很长的路要走。从业二十余年,我见过不少的年轻人,抱着对游戏的一腔热血,一头扎进游戏开发,想着自己有一天也能开发出一款爆款游戏,从此“走上人生巅峰”。
然而走着走着,发现要学的东西太多,无从下手,直接放弃;或者学了之后,因为一直写不出什么项目,也放弃了。就好像去少林寺学武功的人,方丈让他先捆着沙包登山、挑水,他以为这并不是学武术,因此就放弃了。
事实上游戏开发,甚至编程都是这样,你首先要学好基础知识,有了扎实的基础,才可能去做更多的事。道理我想你都懂,我就不多啰嗦啦。我们进入正题。
还记得,在专栏最开始的时候,我专门写过[游戏的分类](https://time.geekbang.org/column/article/8104)按呈现效果我们可以粗略分为2D游戏和3D游戏按硬件我们可以分为主机游戏、电脑游戏、移动游戏和电视机游戏。但是如果从真正的开发角度我会把游戏开发分为**原生游戏开发**和**网页游戏开发**。
为什么这么分呢首先我这个分类中并没有把网络服务器端的内容放进来而只是针对游戏客户端部分。我将它分为原生客户端PC、手机非HTML5原生App和网页客户端PC端页游、HTML5游戏、手机端HTML5游戏、微信小游戏
我们先从原生客户端讲起。
在专栏里我通过Pygame做了示例但是碍于你可能不仅是个游戏开发新手还可能是个编程新手而我们专栏的侧重点在于帮你认识、了解游戏开发流程知道游戏开发是怎么一回事对于底层的知识我其实没有过多的去介绍。
我本身是写服务器端的,对于底层知识研究了很多,所以,我深知底层知识对于一个真正想要在游戏开发之路走得长远的人的重要性。学习的过程,我没有办法替你做,但是我想应该有那么一些经验还可以跟你讲一讲,不至于你在一些可以避免走弯路的地方,浪费掉许多时间。
开发原生客户端游戏需要非常系统的底层知识。这里的底层知识指的是计算机移动设备的硬件底层知识比如内存、CPU、图形显卡等等。当然如果要学得全面你还可以学习物理引擎、音频等等。
## 想走捷径去学C++吧!
**如果你的学习时间并不充裕或者非常迫切地想知道“底层是什么底层做了点什么”想相对快速地能学习到底层知识那么我推荐你直接学习C++。**
首先从执行效率看C++的执行效率仅次于汇编约等于C。如果要编写更底层的操作系统因为语法糖太多你不知道编译器在背后做了什么事情C++语言将无法“直接”掌控底层设备。所以要写操作系统需要对C++编译器进行针对性改造。
我们再往上看如果要编写更上层的应用比如桌面应用、动态网页应用这些是C++经历过的“银弹”时代。90年代到2007年左右几乎电脑上所有应用都有C++的身影但是现在桌面应用完全可以使用C#来编写。
网页端就更不用说了PHP、JavaScript、Python每一个都能比C++做得更快、更完美。但是在游戏开发中既需要执行速度相对地又需要开发速度综合下来只有C++最适合。
所以学习C++会让你对底层知识有了一个大致的了解但是如果你没有更进阶地学习C或者汇编那么你的知识面就停留在类、内存分配、对象等层面。
作为二十多年的C++程序员我这里有几个学习C++的心得想跟你分享。
首先C++和C语言并不是一门语言。它们之间的语法结构看起来虽然“相似”但C++相对于C更像是瑞士军刀和匕首之间的关系。它们都有刀的功能而C++除了刀的功能,还有更多的功能。
其次C++是做减法而非加法。把C++所有特性学完会耗费你极大的精力注意是极大不是大量。每一种特性背后都包裹着无数语法糖衣和编译器的“自动化”动作使用C++的人当中,有一部分人经常会“走火入魔”,专门研究一些奇技淫巧的技巧。
所以最好的方法是,**不要执着于语言特性**因为两个不同的编译器可能编译结果都会不同比如一个会出错一个会通过但只要略作修改就能运行。只要不影响具体最终软件的执行就可以了。C++特性太多选择一种或者两种特性来编写整个软件才是发挥C++最大功效的方法。
最后大道至简这对于整个产品、架构、编码都是一句适用的箴言。当然对C++也是如此只有用最简略的方法来编写代码才会让代码快速成型。C++比C多了太多快速搭建的语法功能。尽量利用它的优点比如面向对象、模板等等就能发挥出语言最大的特长。
## 走这个路径,基础更扎实!
如果你有较宽裕的时间学习编程,也希望学习到更多的底层知识,对计算机有一个全面的掌握和了解,那么我推荐你用以下的这个更全面的路径来学习。
以我的经验我建议你先去学习一下C语言。为什么呢因为C语言是汇编的封装C语言的一句语句可以是汇编的几条指令虽然每个C编译器最终生成的汇编指令可能不同但大致方向是一致的。
其次学习C语言能让你从基础的语言语法了解计算机编程是怎么回事。C语言是99.9%的电子设备的基础语言剩下的0.01是汇编)。
学习C语言有太多的入门书。在这里我推荐[《C Prime Plus》](https://book.douban.com/subject/1240002/)绝对的C语言入门经典教材。[《C Programming Language》](https://book.douban.com/subject/1139336/),读完 《C Prime Plus》之后再去读这本书绝对会让你了解什么是高手所写的书。
看完了《C Programming Language》之后你除了是C程序员之外俨然是一个不错的Linux用户了。
学习完C语言后你可以学习汇编语言。有了C语言的基础对编程、地址操作、位操作这些基础学习汇编就会相对容易。
估计看到汇编语言这几个字,很多人就望而却步了。但是,我想说,**没有比汇编更适合学习底层知识的语言了**。
毕竟在现实中除非你编写的是芯片或者操作系统现在编写芯片或者操作系统也大量使用C语言只有占那1%的启动部分代码会使用汇编。这么看,使用汇编编程的人真的非常少,而且它本身也不适合编写大型项目。
你可能要问了,为什么你还推荐我从汇编开始学呢?学习汇编的意义在哪里?
我们先来看一段指令。
```
pushl %ebp
movl %esp,%ebp
subl $8,%esp
```
在汇编里这些指令就代表着CPU的指令操作。在编写中级、高级语言需要调试代码的时候如果没有调试信息最终都会落到汇编语言这里。这时候汇编语言就是你的最后一道防线学习了汇编你就能快速、深入地定位程序的问题所在。
所以,**学习汇编的意义就是,你能在脑中完全掌握电脑的运行规律和运作逻辑**比如内存寻址操作、寄存器操作、加减操作、CPU指令等等。
学习汇编有一本书,是绝对的入门级好书,能够把深奥枯燥的机器知识讲得生动活泼,那就是王爽的[《汇编语言》](https://book.douban.com/subject/3037562/)。
学习了汇编语言也会对你的C语言知识有一个本质上的巩固。所以结合C和汇编指针不再是头疼的问题因为你已经知道在汇编中的地址是如何操作的。
C语言看起来就好像把汇编进行了一次朴素的包装你不再需要强制记忆寄存器和指令定义一个变量就知道汇编语言是怎么做的这对于你的C语言来说是有绝对帮助意义的。
**一般人提倡的学习路径是由浅入深,如果你想一直在技术领域深耕下去,我建议你走一条由难到易的学习路径。**
因为,越高级的编程语言越接近人类的思维方式,这种思维会固化你的编程思维,让你在之后的学习过程中,无法更深层次地理解底层机器语言的沟通方式,学习起来就会比较困难。先学习底层知识,这样你在后续的高级语言的学习中,就属于“降维打击”,学习起来就相对轻松和快速。
除此之外,如果你已经是一名程序员,你应该很能体会,你的工作将会越来越忙,几乎没有时间学习新的知识,而学习能力是一名程序员必备的基本能力。
接下来你还是需要学C++语言了。具体原因其实我刚才也说了游戏引擎绝大部分使用C++编写也有一小部分是使用C语言或者汇编编写的比如Allegro。
如果你要学习C++语言学苑出版社出版的HerbertSchildt写的《C++从入门到精通》这本书一定不能错过它是我的C++启蒙书。唯一可惜的是这本书年头有些久了我的书还没有找到但是我至今对书的内容都记忆犹新。这本书后面的小习题绝对能让你在学完这本书之后对C++了解的非常透彻和深刻。
另外,[《深](https://book.douban.com/subject/1091086/)[度探索](https://book.douban.com/subject/1091086/)[C++对象模型》](https://book.douban.com/subject/1091086/)[《C++ Programming Language》](https://book.douban.com/subject/1099889/)[《C++语言的设计与演化》](https://book.douban.com/subject/1096216/)也是必看书籍。前一本能让你了解C++对象模型从底层了解C++的机制。后两本出自C++之父Bjarne Stroustrup之手。
从C++开始设计到现在为何会如此演化和设计语言的背后又是怎样的故事除了语言的基础知识也会有一些小小的故事。另外如果你的知识面和时间允许我建议你最好去看《C++ Programming Language》的原版因为只有原版是原汁原味不会有被翻译偏差影响的。
现在,我们已经将一幢大楼的“地基”都搭建好了。
## 学完这些,要多久啊?
你可能会问了,从开始学习底层知识,到对知识有了解并且能顺利写出软件需要多久呢?因人而异,有人是计算机系的,有人是野路子,有人对计算机特别有天赋,有人虽然不聪明但是非常勤奋,每个人的学习曲线和学习路径以及最终学会的时间都是不一样的。
但是一般来说要从C到汇编再到C++一直到能编写成熟的代码平均下来需要57年的时间。我没有做过精细地统计但是我想按照大学四年的学习时间从学习到实践再加上毕业13年的实践深入57年的时间基本是差不多的。你觉得呢
今天这些内容主要涉及游戏开发的底层知识。说起来很容易,做起来却一点都不容易。有了这些基本功,下一节,我会推荐一些游戏原理和机制相关的书籍。希望我的分享对你有帮助。