《十诫》是预定大四结束前就写的东西,但是,由于一贯的懒散与迟钝,以及对情感的无法把握,以至于这个期望能用一种客观、辩证的语调写出来的东西,最终只完成了让自己摇头的一半。
一年结束了,契约也马上就要于12月上旬结束了,由于家里的事情,我将拜别游戏产业回家。此去经年,谁知又何时才能归来?即便是回来了,又当如何?当然这都是未来的问题了,而未来的问题是无从去定义和追索的。
现在目光的焦点回到问题与回答问题的交锋中:
而第一个问题就是游戏程序员是什么?任务是什么?工作是什么?
2003年12月初找到这份工作,初时的工作是让自己感到异常的惶恐,因为我在此之前我自己觉得能拿出手的作品只是一个2D小游戏,以及在其他几个小组内部的3D游戏中起到些很有限的作用而已。毕业论文中所写的东西,大部分只是在思考中,或者尚未经过实践的,到我现在真的去实践他们,才发现有这么多细节需要去注意。可以说我是以零的起步来到了一个3D游戏项目组,从那时起,“你喜欢编游戏吗?”这个问题已经退居二位,关键是“我要做什么?怎么做?”
当初因为对OGRE的诚惶诚恐形成的一个基本的认识是不写引擎,因为引擎对我来说相距太远,我根本不可能去驾驭一个类如OGRE、类如Irrlicht或者Neo这样架构完整而且全面的引擎。我负责的也恰好是游戏层的东西,第一个就是做一个弹道计算器,我对它的认知只限于这个东西会在游戏的技能系统中大量采用,可以决定一些在资源那里无法决定的计算方式:例如跟踪弹道等等。
后来也就顺水推舟作了技能系统,第一次设计的技能系统异乎寻常地糟糕,还记得当时设计时的心情:没有参考,没有这个没有那个,好像唯一所做的就是为每一个技能硬编码硬编码,除了在代码里编制所需的数据之外,还要在代码里硬性指定弹道数据。如果说第一次设计有什么还值得自己稍稍满意一些,那就好像只有把“技能”和“状态”分离这个比较值得自己“臭屁”了,因为这个设计在后来分析魔兽技能编辑器的时候,发现与魔兽的思路基本相同。
糟糕设计所产生的代价是必然的,美工给我一个数据,一个模型,一个特效,我要很长时间,编写弹道模型,编写渲染方式,然后才能写进去,而且很多地方充满了反复编码。曾经看过OGRE,被其过度设计所折服的我,最后趁着重构的时候不加思索删掉所有技能系统代码,删掉了那些——用老大一句话说——“这么狗屎的设计”。
在古代的传说中,有一种“游侠”,天马行空,行侠仗义。我在学校时天马行空惯了,当我发现在课堂上偷着在算草纸上写代码画类图的生活很累后,就在校外租了房子不再上课。第一次设计过后我知道自己根本不算是这种“游侠”,多也不过就是一个“走徒”,云游四方,却不知道为了什么目的,只是觉得这样走或许会好些,或许会有力——实际上除了浪费体力一点用还没有。
很早前,看到过金点对他们《圣剑英雄传》的描述,很是佩服。早期的游戏程序员大多是孤胆游侠出身,很多大侠,大牛。参与了一个真实的项目才发觉这种天马行空的思考方式从根本上说没有大的意义,你天马行空别人还想天马行空呢,这么多人交流、讨论、争吵、攻伐,一个小小的程序员在一个3DMMORPG的游戏系统之中能算得了什么?只是中国的国情实在特殊,使得程序员奇货可居罢了。
游戏如此巨大,模块如此之多,人员如此参杂。程序员到底算做什么?是天使?是魔鬼?是正义?还是邪恶?
作为一个程序,就是为了完成需求,这个需求不仅仅来自于自己,也更大的可能会来自别人。
这些需求包括最基本的需求:引擎,包括各式各样的功能,模块的调用风格和定义。这是程序与程序的交流的问题,还有的就是策划和美工的要求:更多集中在编辑器上。
游戏复杂吗?不觉得,其实游戏用到的大家都知道是怎么回事,但是关键在于多个人对游戏都是各不相同的理解,因此游戏开始变得复杂。
我总是希翼C++能为我完成自己需要的功能,但是后来我发现这些东西本来就应该让那些策划和美工去做。程序总是站在自己的角度上考虑问题,美工也总是站在自己的角度上考虑问题,策划就更爱在自己的角度上考虑问题了。如果三角形的三个极点互不相让,丑陋不堪的在人类契约的保护之下妄图维持三角形那优美的形体之时,失败的命运就已经悄悄确定了。游戏是工程,不是一个人的玩具,也不是几个人的玩具,它是所有参与游戏项目的人共同要面对的课题。
期望着游戏为自己带来财产和地位的人,还不如去买彩票或者傍大款,如果没有性病、艾滋和社会问题这一类说法,或许做鸡更能快速带来财富和快感。游戏是一个普通到不能再普通的工程,从原理上说他和一个网站的工程和一个操作系统的工程没有任何不同,其关键都在于协作、争辩、求同、存异的整体工作。策划说我有一个好的想法,你们程序要实现,很多新手策划不懂程序,他们不知道对于他们,仅仅加入一两个“可变性”,需要程序去实现更多、更复杂、更为沉重的“不变性”。没有换装和加上换装,数值上只是多几个小得不能再小的变量来记取装备编号,但是程序的工作量将要扩大多少?与此类同,如果两个系统间不能好好合作,那么结果肯定是两个系统都不想面对的结果。
我总是说美工做得不好,以此来掩盖自己技能系统设计的重大问题,但是我真正考虑了美工的需要吗?完全没有,我忽视了一个重点:游戏不是我心目中的游戏,而是所有人共同协作的结晶。如果现在那位已经离开公司的美工恰巧在看我的文章,那么我只希望向他说一声“对不起,我险些忘了,我们是同事”。
我总是抱怨别人提供的系统似乎总有这样那样的问题,而没有继续去探询问题来自何方。物件系统逻辑中在STL的使用上出了一些问题,导致对物件系统的管理要求很高的技能特效总是挂在及其怪异的地方,但这时我只是希翼别人去解决这个问题。现在的我总是在回想这些事情,充满愧疚。主程,他的事情本来就很忙,划分系统哪个主程都应该是顾大局的,而顾大局的同时还能顾小体本身就是不容易的事情。就像一个将军他不会去亲自用枪杀人,但是他比一个士兵所面对的压力更大,一个士兵在战后只要活下来,他大凡可以逃避“反人类罪”、“杀人罪”,但是一个将军将要面对那些道貌岸然的战争法庭的审判。我在大学时对物件系统的思考延续了一年有余,而且毕竟自己在OGRE基础上自己封装过物件管理,项目中这些小局问题本身就应该是我继续思考、找出问题、商量问题、解决问题。但我逃避了,把这种零碎的小事情一个个交给别的成员。别人顶着天,1米85的我却躺在那里睡觉。
没有人骂我,所以我心存侥幸,所以,到现在,我只能送给自己这个“道貌岸然”和“卑鄙”的头衔,以此希望能给自己一点心灵的安慰。如果,我的第一位项目经理哪一天也看到了我这篇文章,我期望您能接受我的道歉,真的,对不起。
作为一个普通程序员,在提出自己意见的同时我不能自作主张去更改别人也已定下的规矩。我或许会为了省下100行代码而爽得不行,但是别人会为我这种背叛的行为付出10000行代码的代价去修补他们的代码。主程的话你不是必须要听,有不同的方案和见解可以跟主程讨论,但是,一旦定下来,即便有1000万个不愿意,你也要完成。主程面前是整个系统,你的面前最多是自己的模块。所以如果你真的还对这个项目有一点感情,拜托就让自己多写100行代码吧。当然你自己认为的“好”方案,你难道不能自己抽时间去实现他吗?我曾经考虑过一个技能模型(未经过试验),就是通过大量运用配置文件,可以让策划自己实时去调整技能的所有细节。但是最终被否决了,因为网络游戏是撑不了这么大的开销的。网络游戏虽然系统很大,但是模块却又要尽力短小精悍,OGRE的过度设计方针并不是在任何地方都能用的,因为你不可否认OGRE在几个开源引擎中效率并不是最好的。有些游戏是重质量不重效率,而有些游戏则不得不为了游戏效率去舍弃很多东西。
如果我是主程序呢?我没做过,不知道。我私下认为一个主程序不应该对重构抱有太多的希望。重构是当大厦千疮百孔的时候炸掉重来的方式,但如果大厦建到了沙漠里,那炸掉重来千万遍,结果都是一样的。好的初期设计可以减少被拉登投机的机会,XP适用于小规模、变化律高的程序设计,并不适于大规模、小变化律的程序设计。这个是源自于某天跟一位同学的聊天,跟我参加的工程无关,我所参加的工程除了技能系统重构一次、模型重构一次、网络重构一次、地图重构一次外没有别的重构了,但是这四次重构几乎重新开发了整个系统,那初期的设计究竟是否是所有人把方案经过好好讨论、磨合而产生的呢?我自己的技能系统没有,这是我的错。一个人曾经开发过什么成功的东西,并不意味着同样的方式能在另一个系统上成功。我们所说的成功都是相对的,成功是大量矛盾在一种特殊条件下的表现,而且这种表现可被人类所认同,成功和失败只是在人类这里才有的概念。这个概念现在就成为了:一个人曾经开发过包含了一堆矛盾的东西,并不意味着他用同样的方式开发这个系统时这一堆矛盾还会以原来那种形态重现。同是兵书,十个人读却有十一种打仗的风格,看似相同的两场战役,却总会有些细微的差别,因此产生完全不同的结果。这是有参照的情况,何况我还没有参照呢。以后还有机会的话,更应该多注意询问需求,好好分析,寻找参照,解决问题。一个积极的人总比一个消极的人占有更多主动权。
(未完)
分享到:
相关推荐
一、项目简介 包含:项目源码、数据库脚本等,该项目附带全部源码可作为毕设使用。 项目都经过严格调试,eclipse或者idea 确保可以运行! 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷 二、技术实现 jdk版本:1.8 及以上 ide工具:IDEA或者eclipse 数据库: mysql5.5及以上 后端:spring+springboot+mybatis+maven+mysql 前端: vue , css,js , elementui 三、系统功能 1、系统角色主要包括:管理员、用户 2、系统功能 前台功能包括: 用户登录 车位展示 系统推荐车位 立即预约 公告展示 个人中心 车位预定 违规 余额充值 后台功能: 首页,个人中心,修改密码,个人信息 用户管理 管理员管理 车辆管理 车位管理 车位预定管理,统计报表 公告管理 违规管理 公告类型管理 车位类型管理 车辆类型管理 违规类型管理 轮播图管理 详见 https://flypeppa.blog.csdn.net/article/details/146122666
项目已获导师指导并通过的高分毕业设计项目,可作为课程设计和期末大作业,下载即用无需修改,项目完整确保可以运行。 包含:项目源码、数据库脚本、软件工具等,该项目可以作为毕设、课程设计使用,前后端代码都在里面。 该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 项目都经过严格调试,确保可以运行!可以放心下载 技术组成 语言:java 开发环境:idea 数据库:MySql 部署环境:maven 数据库工具:navica 更多毕业设计https://cv2022.blog.csdn.net/article/details/124463185
内容为Python程序设计的思维导图,适用于新手小白进行浏览,理清思路
2024-Stable Diffusion全套资料(软件+关键词+模型).rar
mmexport1741417035005.png
COMSOL三维锂离子电池全耦合电化学热应力模型:模拟充放电过程中的多物理场耦合效应及电芯内应力应变情况,COMSOL锂离子电池热应力全耦合模型,comsol三维锂离子电池电化学热应力全耦合模型锂离子电池耦合COMSOL固体力学模块和固体传热模块,模型仿真模拟电池在充放电过程中由于锂插层,热膨胀以及外部约束所导致的电极的应力应变情况结果有电芯中集流体,电极,隔膜的应力应变以及压力情况等,电化学-力单向耦合和双向耦合 ,关键词: 1. COMSOL三维锂离子电池模型; 2. 电化学热应力全耦合模型; 3. 锂离子电池; 4. 固体力学模块; 5. 固体传热模块; 6. 应力应变情况; 7. 电芯中集流体; 8. 电极; 9. 隔膜; 10. 电化学-力单向/双向耦合。,COMSOL锂离子电池全耦合热应力仿真模型
基于传递矩阵法的一维层状声子晶体振动传输特性及其优化设计与应用,声子晶体传递矩阵法解析及应用,Matlab 一维层状声子晶体振动传输特性 传递矩阵法在声子晶体的设计和应用中具有重要作用。 通过调整声子晶体的材料、周期和晶格常数等参数,可以设计出具有特定带隙结构的声子晶体,用于滤波、减震、降噪等应用。 例如,通过调整声子晶体的周期数和晶格常数,可以改变带隙的位置和宽度,从而实现特定的频率范围内的噪声控制。 此外,传递矩阵法还可以用于分析和优化声子晶体的透射谱,为声学器件的设计提供理论依据。 ,Matlab; 一维层状声子晶体; 振动传输特性; 传递矩阵法; 材料调整; 周期和晶格常数; 带隙结构; 滤波; 减震; 降噪; 透射谱分析; 声学器件设计,Matlab模拟声子晶体振动传输特性及优化设计研究
头部姿态估计(HeadPose Estimation)-Android源码
永磁同步电机FOC、MPC与高频注入Simulink模型及基于MBD的代码生成工具,适用于Ti f28335与dspace/ccs平台开发,含电机控制开发文档,永磁同步电机控制技术:FOC、MPC与高频注入Simulink模型开发及应用指南,提供永磁同步电机FOC,MPC,高频注入simulink模型。 提供基于模型开发(MBD)代码生成模型,可结合Ti f28335进行电机模型快速开发,可适用dspace平台或者ccs平台。 提供电机控制开发编码器,转子位置定向,pid调试相关文档。 ,永磁同步电机; FOC控制; MPC控制; 高频注入; Simulink模型; 模型开发(MBD); Ti f28335; 电机模型开发; dspace平台; ccs平台; 编码器; 转子位置定向; pid调试。,永磁同步电机MPC-FOC控制与代码生成模型
light of warehouse.zip
内容概要:文章深入讨论了工业乙醇发酵的基本原理及工艺流程,特别是在温度和气体排放(如CO2及其他有害气体)影响下的发酵效果分析。文章介绍了乙醇发酵的重要环节,如糖分解、代谢路径、代谢调控以及各阶段的操作流程,重点展示了如何通过Matlab建模和仿真实验来探索这两个关键环境因素对发酵过程的具体影响。通过动态模型仿真分析,得出合适的温度范围以及适时排除CO2能显著提升发酵产乙醇的效果与效率,从而提出了基于仿真的优化发酵生产工艺的新方法。 适用人群:从事生物工程相关领域研究的科学家、工程师及相关专业师生。 使用场景及目标:适用于实验室环境、学术交流会议及实际生产指导中,以提升研究人员对该领域内复杂现象的理解能力和技术水平为目标。 其他说明:附录中有详细的数学公式表达和程序代码可供下载执行,便于有兴趣的研究团队重复实验或者继续扩展研究工作。
本资源包专为解决 Tomcat 启动时提示「CATALINA_HOME 环境变量未正确配置」问题而整理,包含以下内容: 1. **Apache Tomcat 9.0.69 官方安装包**:已验证兼容性,解压即用。 2. **环境变量配置指南**: - Windows 系统下 `CATALINA_HOME` 和 `JAVA_HOME` 的详细配置步骤。 - 常见错误排查方法(如路径含空格、未生效问题)。 3. **辅助工具脚本**:一键检测环境变量是否生效的批处理文件。 4. **解决方案文档**:图文并茂的 PDF 文档,涵盖从报错分析到成功启动的全流程。 适用场景: - Tomcat 9.x 版本环境配置 - Java Web 开发环境搭建 - 运维部署调试 注意事项: - 资源包路径需为纯英文,避免特殊字符。 - 建议使用 JDK 8 或更高版本。
这是一款仿照京东商城的Java Web项目源码,完美复现了360buy的用户界面和购物流程,非常适合Java初学者和开发者进行学习与实践。通过这份源码,你将深入了解电商平台的架构设计和实现方法。欢迎大家下载体验,提升自己的编程能力!
系统选用B/S模式,后端应用springboot框架,前端应用vue框架, MySQL为后台数据库。 本系统基于java设计的各项功能,数据库服务器端采用了Mysql作为后台数据库,使Web与数据库紧密联系起来。 在设计过程中,充分保证了系统代码的良好可读性、实用性、易扩展性、通用性、便于后期维护、操作方便以及页面简洁等特点。
这是一款专为大学生打造的求职就业网JavaWeb毕业设计源码,功能齐全,界面友好。它提供简历投递、职位搜索、在线交流等多种实用功能,能够帮助你顺利进入职场。无论你是想提升技术水平还是寻找灵感,这个源码都是不可多得的资源。快来下载,让你的求职之路更加顺畅吧!
useTable(1).ts
实验一: 1、进行CCS6.1软件的安装,仿真器的设置,程序的编译和调试; 2、熟悉CCS软件中的C语言编程; 3、使用按键控制LED跑马灯的开始与停止、闪烁频率; 4、调试Convolution、FFT、FIR、FFT-FIR实验,编制IIR算法并调试,并在CCS软件上给出实验结果。 实验二: 1、利用定时器周期中断或下溢中断和比较器比较值的修改来实现占空比可调的PWM波形; 2、改变PWM占空比控制LED灯的亮暗,按键实现10级LED灯亮暗调整; 3、模拟数字转换,转换过程中LED指示,并在变量窗口显示转换结果; 4、数字模拟转换,产生一个正弦波,转换过程中LED指示,转换完成后在CCS调试窗口显示波形。 实验三: 1、SCI异步串行通信实验; 2、SPI及IIC同步串行通信实验; 3、CAN现场总线串行通信实验; 4、传输过程中LED指示。 实验四: 1、电机转速控制实验。
LINUX系统管理与配置.docx
chromedriver-mac-x64-136.0.7055.0.zip
地级城市驻地,dbf 地级城市驻地,prj 地级城市驻地.sbn 9 地级城市驻地.sbx 地级城市驻地.shp 地级城市驻地.shx 9 国界线.dbf 国界线.prj 国界线.sbne 国界线.sbx 国界线.shp 国界线.shx )经纬网.dbf ]经纬网.prj 经纬网.sbn 经纬网.sbx 经纬网.shp 经纬网.shx 全国县级统计数据.dbf 全国县级统计数据,prj 全国县级统计数据.sbr 全国县级统计数据.sbx 全国县级统计数据.shp 全国县级统计数据.shx )省会城市.dbf 省会城市,prj 省会城市.sbn 省会城市.sbx 省会城市.shp 省会城市.shx 省级行政区.dbf 省级行政区,pn 省级行政区.sbn 省级行政区,sbx 9 省级行政区.shp 9 6 省级行政区,shx 县城驻地.dbf 县城驻地,prj 擷垃岑械鰣媛城驻地.sbr 藶勇瑁鴎隐城驻地.sbx 县蓿玨蒴城驻地.shp 苽6城驻地,shx 线状省界.dbf 线状省界,prj 1线状首界,sbn 线状省界.sbx 线状首界.shp 线状省界,shx 线状县界,dbf □]