原创 正确地做事与做正确的事同样重要

2010-6-15 11:33 1358 4 4 分类: 工程师职场

 


ASPDelphiJavaC++、从初级编码员到系统架构师、调程序、做方案,熬通宵、蹲机房、这就是本人风雨6年的程序人生。平时主一直喜欢反思繁重而枯燥的软件开发任务、总结精巧而雅致的分析设计技巧、融合传统或新颖的开源框架思想。而今,将个人平时的思想常常或个人观点剪辑成文,希望对所有工程师有所帮助,早日实现自己的人生目标。<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />


谨以此文献给那个自己为之奉献3年青春与激情的开发团队,以及所有团队成员。


1.          分享第一条经验:“学历代表过去、能力代表现在、学习力代表未来。”


其实这是一个来自国外教育领域的研究结果。相信工作过几年、十几年的朋友对这个有些体会吧。但我相信这一点也很重要:“重要的道理明白太晚将抱憾终生!”所以放在第一条,让软件工程师早点看到!


2.          一定要确定自己的发展方向,并为此目的制定可行的计划。不要说什么:“我刚毕业,我刚入行,还不知道将来可能做什么?”,“跟着感觉走,先做做看。”因为,这样的观点会通过你的潜意识去暗示你会无所事事、得过且过。一直做技术,将来成为专家级人物?向管理方向走,成为职业经理众人人?先熟悉行业和领域,将来自立门户?还是先在行业里面混混,过几年转行做点别的?确定你的发展方向很重要,它将决定你近几年、十年内“做什么事情才是在做正确的事情!”


3.          软件开发团队中,技术不是万能的,但没有技术是万万不能的!在技术型团队中,技术与人品同等重要。在软件项目团队中,技术水平是受人重视和尊重的重要砝码。无论你是做管理、系统分析、设计、编码,还是产品管理、测试、文档、实施、维护,多少你都要有技术基础。算我孤陋寡闻,我还真没有亲眼看到过一个外行带领一个软件开发团队成功地完成过开发项目,哪怕就一个,也没有看到。倒是曾经看到过一个“高学历的牛人”(非技术型)带一堆人做完过一人项目,项目将会的第二天,项目组成员扔下一句“再也受不了啦!”就四分五裂、各奔东西了。那个项目的“成功度”大家可想而知了。


4.          详细制定自己软件开发专业知识学习计划,并注意及时修正和调整(开发技术变化实在太快)。请牢记:“如果一个软件开发人员在一两年内都没有过自已的知识,那么,其实他已经不再属于这个行业了。”不要告诉自己没有时间。来自时间管理领域的著名的“三八原则”告诫我们:另外的那8小时如何使用将决定你一生的成败!本人自毕业以来,平均每天实际学习时间超过1.5小时


5.          书籍是人类的阶梯,对开发人员尤其如此。书籍是学习知识的最有效途径,还要过多地指望在工作中能遇到“世外高人”,并不厌其烦地教你。


“拥有书籍并不表示拥有知识;拥有知识并不表示拥有技能;拥有技能并不表示拥有文化;拥有文化并不表示拥有智慧。”只有将书本变成自己的智慧,才算是真正拥有了它。


6.          不要仅局限于对某项技术的表面使用上,哪怕你只是偶尔用一两次。“对任何事物不究就里”是任何行业的工程所不该具备的素质。开发Windows应用程序,看看Windows程序的设计,加载、原理,分析一下PE文件格式,试试用SDK从头开发一个Windows应用程序;用VC++DelphiJavaNet开发应用程序,花时间去研究一下MFCVCLJ2EE.Net框架设计或者源码;除了会用J2EEJBossSpringHibernate等优秀的开源产品或者框架,还要抽空看看大师们是如何抽象、分析、设计和实现那些类似问题的通用解决方案的。试着这样做做,你以后的工作将会少遇到一些让你不明就里,一头雾水的问题,因为,很多东西你“知其然且知其所以然!


7.          在一种语言上编程,但别为其束缚了思想。“代码大全”中说:“深入一门语言编程,不要浮于表面。”深入一门语言开发还远远不足,任何编程语言的存在都有其自身的理由,所以也没有哪门语言是“包治百病”的“灵丹妙药”编程语言对开发人员解决具体问题的思路和方式的影响与束缚的例子俯拾皆是。


我的经验是:用面对对象工具某些关键模块时,为什么不可以借鉴CC51、汇编的模块化封闭方式?用传统的桌面开发工具(目前主要有VC++Delphi)进行系统结构设计时,为什么不可以参考来自Java社区的IoCAOP设计思想,甚至借鉴像SpringHibernateJboss等优秀的开源框架?在进行类似于实时通信、数据采集等的设计,实现时,为什么不可以引用来看在实时系统、嵌入式系统的优秀的体系框架与模式?为什么一切都发源以个人、团队在某个开发语言上的传统或者经验来解决问题???“他山之石,可以攻玉”。


8.          养成总结与反思的习惯,并有意识地提炼日常工作成果,形成自己的个人源码库、解决某类问题的通用系统体系结构、甚至进化为框架。众所周知,对软件开发人员而言,有、无的一个显著区别是:无经验者完成任何任务时都从头开始,而有经验者往往通过重组自己的可复用模块、类库来解决问题(其实这个结论不该被局限在开发领域,可以延伸到很多方面)。这并不是说,所有可复用的东西都必须自己实现,别人成熟的通过测试的成果也可以收集、整理、集成至自己的知识库中。但是最好自己实现,这样没有知识产权、版权等问题,关键是自己实现后能真正掌握这个知识点,拥有这个技能。


9.          理论与实践并重,内外双修。工程师的内涵是:以工程师的眼光观察分析事物和世界。


一个合格的软件工程师,是真正理解了产品的本质及产品研发的思想精髓的人(个人观点、欢迎探讨)。掌握开发语言、应用语言工具工作中的具体问题、完成目标任务是软件工程师的主要工作,但从工程师这个角度,这只是外在的东西,并非重要的、本质的工作。学习、掌握软件产品开发理论知识,软件开发方法论,并在开发理论知识、软件产品的分析,设计、实现思想来解决具体的软件产品研发问题,者真正的工程师的工作。站在成熟理论与可靠方法论的高度思考、分析、问题,并存具体实践中验证和修正这些思想与方式,最终形成自己的理论体系和实用方法论。


10.      心态有多开放,视野应有地多开阔。还要抱着自己的技术和成果,等到它们都已经过时才拿出来。请及时发布自己的研究成果;开发的产品、有创意的设计或代码,公布出来与大家交流或都使用,你的成果才有进化和升华的机会。


想想自己2000年时开发的那些Windows系统工具,五六年之后的今天,还是那个样子,今天流行的好多系统工具都比自己的晚,但进化得很好,且有那么多用户在使用。并且,不要保守自己的技术和思想,尽可能地与人交流与分享,或者传授给开发团队的成员。“与人交换苹果之后,每个人还是只有一个苹果;但交换思想之后,每个人就拥有两种思想”道理大家都懂,但有多少人真正能做到呢?


11.      尽量参加合伙人开发,或者与朋友共同研制一些自己的产品,千万不要因为没有钱赚而不做。网络早已不再只是“虚拟世界”,网上有很多的开源项目、合作开发项目、外包项目,这者是涉猎工作的知识的绝好机会,并且能够结识更广的人缘。不要因为工作是做ERP,就不会学习和了解嵌入式、实时通信、网络等方面的技术,反过来也是一样。如果当别人拿合同找你合作,你却这也不会,那也不熟时你将后悔莫及。


12.      书到用时方恨少,还要将自己的知识面仅仅局限于技术方面。诺贝尔经济学奖得主西<?xml:namespace prefix = st1 ns = "urn:schemas-microsoft-com:office:smarttags" />蒙教授的研究结果表明:“对于一个有一定基础的人来说,他只要真正肯下功夫,在6个月内可以掌握任何一门学问。”教育心理学界为感谢西蒙教授的研究成果,故命名为西蒙学习法。可见,掌握一门陌生的学问远远没有想象的那么高难、深奥。


多方吸取、广泛涉猎。极力夯实自己的影响圈,尽量扩大自己的关注圈。财务、经济、税务、管理等知识,有空就时间看看,厚积薄发、未雨绸缪。


反思


A不要去做技术上的高手,除非你的目标如此。虽然本文是关于提软件开发的知识的建议,做技术的高手是我一向都不赞同的。你可以提高自己的知识,但能胜任工作即止。


B:提高软件知识和技术只是问题的表面,本质是要提高自己认识问题,分析问题,解决问题的思想高度。软件专业知识的很多方法和原理,可以很容易地延伸,应用到生活的其他方面。


C:在能用途工作的基础上,立即去涉猎其他领域的知识,丰富自己的知识体系,提高自己的综合素质,尤其是那些不在技术方面的朋友


 

PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
我要评论
0
4
关闭 站长推荐上一条 /3 下一条