一位软件工程师的经验总结.docx
《一位软件工程师的经验总结.docx》由会员分享,可在线阅读,更多相关《一位软件工程师的经验总结.docx(11页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、一位软件工程师的经验总结 一位软件工程师的阅历总结一位软件工程师的6年总结“又是一年毕业时”,看到一批批学子离开人生的象牙塔,走上各自的工作岗位;想想自己也曾经意气风发、踌躇满志,不觉感叹万千本文是自己工作6年的经验沉淀或者阅历提炼,希望对全部的软件工程师们有所帮助,早日实现自己的人生目标。本文主要是关于软件开发人员如何提高自己的软件专业技术方面的详细建议,前面几点旨在确定大的方向,算是废话吧。1、共享第一条阅历:“学历代表过去、实力代表现在、学习力代表将来。”其实这是一个来自国外教化领域的一个探讨结果。信任工作过几年、十几年的挚友对这个道理有些体会吧。但我信任这一点也很重要:“重要的道理明白
2、太晚将抱憾终生!”所以放在每一条,让刚刚毕业的挚友们早点看到哈!2、肯定要确定自己的发展方向,并为此目的制定可行的安排。不要说什么,“我刚毕业,还不知道将来可能做什么?”,“跟着感觉走,先做做看”。因为,这样的观点会通过你的潜意识去示意你的行为无所事事、无所作为。始终做技术,将来成为专家级人物?向管理方向走,成为职业经理人?先熟识行业和领域,将来独立门户?还是先在行业里面混混,过几年转行做点别的?这很重要,它将确定你近几年、十年内“做什么事情才是在做正确的事情!”。3、软件开发团队中,技术不是万能的,但没有技术是万万不能的!在技术型团队中,技术与人品同等重要,当然长相也比较重要哈,尤其在MM比
3、较多的团队中。在软件项目团队中,技术水平是受人重视和敬重的重要砝码。无论你是做管理、系统分析、设计、编码,还是产品管理、测试、文档、实施、维护,多少你都要有技术基础。算我孤陋寡闻,我还真没有亲眼看到过一个外行带领一个软件开发团队胜利地完成过软件开发项目,哪怕就一个,也没有看到。倒是曾经看到过一个“高学历的牛人”(非技术型)带一堆人做完过一个项目,项目交付的其次天,项目组成员扔下一句“再也受不了啦!”四分五裂、各奔东西。那个项目的“成功度”大家可想而知了。4、具体制定自己软件开发专业学问学习安排,并留意刚好修正和调整(软件开发技术改变实在太快)。请牢记:“假如一个软件开发人员在1、2年内都没有更
4、新过自己的学问,那么,其实他已经不再属于这个行业了。”不要告知自己没有时间。来自时间管理领域的闻名的“三八原则”告诫我们:另外的那8小时如何运用将确定你的人生成败!本人自毕业以来,平均每天实际学习时间超过2小时。5、书籍是人类进步的阶梯,对软件开发人员尤其如此。书籍是学习学问的最有效途径,不要过多地希望在工作中能遇到“世外高人”,并不厌其烦地教你。对于花钱买书,我个人阅历是:千万别买国内那帮人出的书!我买的那些家伙出的书,100%全部懊悔了,无一本例外。更生气的是,这些书在二手市场的地摊上都很难卖掉。“拥有书籍并不表示拥有学问;拥有学问并不表示拥有技能;拥有技能并不表示拥有文化;拥有文化并不表
5、示拥有才智。”只有将书本变成的自己才智,才算是真正拥有了它。6、不要仅局限于对某项技术的表面运用上,哪怕你只是间或用一、二次。“对任何事物不究就里”是任何行业的工程师所不应当具备的素养。开发Windows应用程序,看看Windows程序的设计、加载、执行原理,分析一下PE文件格式,试试用SDK开发从头开发一个Windows应用程序;用VC、Delphi、Java、.Net开发应用程序,花时间去探讨一下MFC、VCL、J2EE、.Net它们框架设计或者源码;除了会用J2EE、JBoss、Spring、Hibernate等等优秀的开源产品或者框架,抽空看看大师们是如何抽象、分析、设计和实现那些类似
6、问题的通用解决方案的。试着这样做做,你以后的工作将会少遇到一些让你不明就里、一头雾水的问题,因为,许多东西你“知其然且知其所以然”!7、在一种语言上编程,但别为其束缚了思想。“代码大全”中说:“深化一门语言编程,不要浮于表面”。深化一门语言开发还远远不足,任何编程语言的存在都有其自身的理由,所以也没有哪门语言是“包治百病”的“灵丹妙药”。编程语言对开发人员解决详细问题的思路和方式的影响与束缚的例子俯拾皆是。我的阅历是:用面对对象工具开发某些关键模块时,为什么不行以借鉴C、C51、汇编的模块化封装方式?用传统的桌面开发工具(目前主要有VC+、Delphi)进行系统体统结构设计时,为什么不行以参考
7、来自Java社区的IoC、AOP设计思想,甚至借鉴像Spring、Hibernate、JBoss等等优秀的开源框架?在进行类似于实时通信、数据采集等功能的设计、实现时,为什么不行以引用来自实时系统、嵌入式系统的优秀的体系框架与模式?为什么一切都必需以个人、团队在当然开发语言上的传统或者阅历来解决问题?“他山之石、可以攻玉”。8、养成总结与反思的习惯,并有意识地提炼日常工作成果,形成自己的个人源码库、解决某类问题的通用系统体系结构、甚至进化为框架。众所周知,对软件开发人员而言,有、无阅历的一个显著区分是:无阅历者完成任何任务时都从头起先,而有阅历者往往通过重组自己的可复用模块、类库来解决问题(其
8、实这个结论不应当被局限在软件开发领域、可以延长到许多方面)。这并不是说,全部可复用的东西都必需自己实现,别人成熟的通过测试的成果也可以收集、整理、集成到自己的学问库中。但是,最好还是自己实现,这样没有学问产权、版权等问题,关键是自己实现后能真正驾驭这个学问点,拥有这个技能。9、理论与实践并重,内外双修。工程师的内涵是:以工程师的眼光视察、分析事物和世界。一个合格的软件工程师,是真正理解了软件产品的本质及软件产品研发的思想精髓的人(个人观点、欢迎探讨)。驾驭软件开发语言、应用语言工具解决工作中的详细问题、完成目标任务是软件工程师的主要工作,但从软件工程师这个角度来看,这只是外在的东西,并非重要的
9、、本质的工作。学习、驾驭软件产品开发理论学问、软件开发方法论,并在实践中理解、应用软件产品的分析、设计、实现思想来解决详细的软件产品研发问题,才是真正的软件工程师的工作。站在成熟理论与牢靠方法论的高度思索、分析、解决问题,并在详细实践中验证和修正这些思想与方式,最终形成自己的理论体系和好用方法论。10、心态有多开放,视野就有多开阔。不要抱着自己的技术和成果,等到它们都已经过时变成垃圾了,才拿出来丢人现眼。请刚好发布自己的探讨成果:开发的产品、有创意的设计或代码,公布出来让大家沟通或者运用,你的成果才有进化和升华的机会。想想自己201*年间开发的那些Windows系统工具,5、6年之后的今日,还
10、是那个样子,今日流行的好多Windows系统工具都比自己的晚,但进化得很好,且有那么多用户在运用。并且,不要保守自己的技术和思想,尽可能地与人沟通与共享,或者传授给开发团队的成员。“与人交换苹果之后,每个人还是只有一个苹果;但交换思想之后,每个人都拥有两种思想”,道理大家都懂,但有多少人真正能做到呢?11、尽量参与开源项目的开发、或者与挚友共同研制一些自己的产品,千万不要因为没有钱赚而不做。网络早已不再只是“虚拟世界”,网上有许多的开源项目、合作开发项目、外包项目,这都是涉猎工作以外的学问的绝好机会,并且能够结识更广的人缘。不要因为工作是做ERP,就不去学习和了解嵌入式、实时、通信、网络等方面
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 一位 软件工程师 经验总结
限制150内