`
lixiamani
  • 浏览: 38840 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

(转)一个软件工程师的经验之谈

 
阅读更多
分享一位软件工程师的7年总结,经验之谈,借此导航自己人生。

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

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

2、一定要确定自己的发展方向,并为此目的制定可行的计划。

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

3、软件开发团队中,技术不是万能的,但没有技术是万万不能的!

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

4、详细制定自己软件开发专业知识学习计划,并注意及时修正和调整(软件开发技术变化实在太快)。

请牢记:“如果一个软件开发人员在1、2年内都没有更新过自己的知识,那么,其实他已经不再属于这个行业了。”不要告诉自己没有时间。来自时间管理领域的著名的“三八原则”告诫我们:另外的那8小时如何使用 将决定你的人生成败!本人自毕业以来,平均每天实际学习时间超过2小时。

5、书籍是人类进步的阶梯,对软件开发人员尤其如此。

书籍是学习知识的最有效途径,不要过多地指望在工作中能遇到“世外高人”,并不厌其烦地教你。对于花钱买书,我个人经验是:千万别买国内那帮人出的书!我买的那些 家伙出的书,100%全部后悔了,无一本例外。更气愤的是,这些书在二手市场的地摊上都很难卖掉。“拥有书籍并不表示拥有知识;拥有知识并不表示拥有技 能;拥有技能并不表示拥有文化;拥有文化并不表示拥有智慧。”只有将书本变成的自己智慧,才算是真正拥有了它。

6、不要仅局限于对某项 技术的表面使用上,哪怕你只是偶尔用一、二次。

“对任何事物不究就里”是任何行业的工程师所不应该具备的素质。开发Windows应用程序,看看 Windows程序的设计、加载、执行原理,分析一下PE文件格式,试试用SDK开发从头开发一个Windows应用程序;用VC++、

Delphi、Java、.Net开发应用程序,花时间去研究一下MFC、VCL、J2EE、.Net它们框架设计或者源码;除了会用J2EE、 JBoss、Spring、Hibernate等等优秀的开源产品或者框架,抽空看看大师们是如何抽象、分析、设计和实现那些类似问题的通用解决方案的。 试着这样做做,你以后的工作将会少遇到一些让你不明就里、一头雾水的问题,因为,很多东西你“知其然且知其所以然”!

7、在一种语言上编程,但别为其束缚了思想。

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

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

8、养成总结与反思的习惯,并有意识地提炼日常工作成果,形成自己的个人源码库、解决某类问题的通用系统体系结构、甚至进化为框架。

众所周知,对软件开发人员而言,有、无经验的一个显著区别是:无经验 者完成任何任务时都从头开始,而有经验者往往通过重组自己的可复用模块、类库来解决问题(其实这个结论不应该被局限在软件开发领域、可以延伸到很多方 面)。这并不是说,所有可复用的东西都必须自己实现,别人成熟的通过测试的成果也可以收集、整理、集成到自己的知识库中。但是,最好还是自己实现,这样没 有知识产权、版权等问题,关键是自己实现后能真正掌握这个知识点,拥有这个技能。

9、理论与实践并重,内外双修。

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

10、心态有多开放,视野就有多开阔。

不要抱着自己的技术和成果,等到它们都已经过时变成垃圾了,才拿出来丢人现眼。请及时发布自己的研究成果:开发的 产品、有创意的设计或代码,公布出来让大家交流或者使用,你的成果才有进化和升华的机会。想想自己2000年间开发的那些Windows系统工具,5、6 年之后的今天,还是那个样子,今天流行的好多Windows系统工具都比自己的晚,但进化得很好,且有那么多用户在使用。并且,不要保守自己的技术和思 想,尽可能地与人交流与分享,或者传授给开发团队的成员。“与人交换苹果之后,每个人还是只有一个苹果;但交换思想之后,每个人都拥有两种思想”,道理大 家都懂,但有多少人真正能做到呢?

11、尽量参加开源项目的开发、或者与朋友共同研制一些自己的产品,千万不要因为没有钱赚而不做。

网络早已不再只是“虚拟世界”,网上有很多的开源项目、合作开发项目、外包项目,这都是涉猎工作以外的知识的绝好机会,并且能够结识更广的人缘。不要因为工 作是做ERP,就不去学习和了解嵌入式、实时、通信、网络等方面的技术,反过来也是一样。如果当别人拿着合同找你合作,你却这也不会,那也不熟时,你将后 悔莫及。

12、书到用时方恨少,不要将自己的知识面仅仅局限于技术方面。

诺贝尔经济学奖得主西蒙教授的研究结果表明:“对于一个有一定基础的人来说,他只要真正肯下功夫,在6个月内就可以掌握任何一门学问。”教育心理学界为感谢西蒙教授的研究成果,故命名为西蒙学习法。

可见,掌握一门陌生的学问远远没有想象的那么高难、深奥。多方吸取、广泛涉猎。极力夯实自己的影响圈、尽量扩大自己的关注圈。财务、经济、税务、管理等等知识,有空花时间看看,韬光养晦、未雨绸缪。

13、本文的总结与反思:

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

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

C:在能胜任工作的基础上,立即去涉猎其它领域的专业知识,丰富自己的知识体系、提高自己的综合素质,尤其是那些目标不在技术方面的朋友。
分享到:
评论

相关推荐

    电子工程师的经验之谈

    【电子工程师的经验之谈】 电子工程师是科技领域中不可或缺的专业人才,他们负责设计、测试和改进电子设备,如电路板、集成电路、计算机硬件等。本文将深入探讨电子工程师的工作价值、职业发展路径以及如何提升自身...

    采购工程师经验之谈(1).doc

    在IT行业中,采购工程师的角色至关重要,他们负责公司硬件、软件和服务的购买,确保资源的合理利用和成本控制。以下是从提供的文件中提炼出的一些关键知识点: 1. **应对价格变动** - 当供应商提出涨价时,采购...

    c语言编程修养之道(一位工程师的经验之谈)

    在《C语言编程修养之道(一位工程师的经验之谈)》这篇文章中,作者分享了自己在程序开发过程中积累的宝贵经验,总结出了三十二条提高编程水平的原则,旨在帮助读者写出高质量、易读且易于维护的代码。 #### 1. ...

    挺进嵌入式----来自多年嵌入式开发工程师的经验之谈

    计算机组成原理要能理解组成一个计算机系统的几大部件,计算机系统的结构,理解系统总线,理解处理器和计算机外部设备的关系,处理器和计算机外设是如何协调工作完成某一项功能的,计算机软件和硬件是如何分工协作...

    经验之谈,工程师在电路设计中的八大误区

    硬件设计确实为设备的功耗提供了一个基础,但软件也在很大程度上影响着功耗。软件可以通过减少对存储器的访问、优化中断响应和其他针对具体硬件的优化措施来降低功耗。 以上就是工程师在电路设计中常见的八大误区,...

    经验之谈,工程师在电路设计中的八大误区.docx

    在电子工程领域,电路设计是核心环节之一,工程师在实践中可能会遇到各种误区,导致设计效率降低,功耗增加,甚至影响系统的稳定性和可靠性。以下是基于给出的文件内容,对电路设计八大误区的详细分析和解释: 1. ...

    赢在测试 中国软件测试先行者之道

    他们的经验和见解是宝贵的,对于每一位软件测试从业人员或者将要进入这个行业的朋友都有着非常积极的借鉴意义。读一本书,聆听多位成功者的经验之谈,明确发展方向,少走一些人生的弯路。  本书适合于软件测试...

    嵌入式开发的工程师经验之谈----(新手必看)

    本文通过一个嵌入式开发的工程师经验之谈,侧面生动详细的为正在学习嵌入式的读者提供学习帮助,希望对读者有所帮助。下面是该文中的知识点总结: 一、嵌入式系统的概念 * 嵌入式系统-from三个方面理解:硬件、...

    pcb 设计经验之谈

    PADS是一款广泛使用的PCB设计软件,以其强大的功能和易用性深受工程师喜爱。本篇文章将详细探讨在PADS中进行PCB设计的经验与技巧。 1. **元器件布局**:PCB设计的第一步是元器件布局。在PADS中,应遵循“先大后小,...

    ANSYS&有限元法\学ansys的经验之谈

    在掌握软件基本操作和理论知识的基础上,非线性问题的处理能力成为衡量一个ANSYS使用者水平高低的关键因素。对于非线性问题,数值计算方法的理解尤为重要,它直接关系到求解器的选择和计算过程的控制。《计算固体...

    Windows环境下32位汇编语言程序设计(第2版)下载

    软件工程师,现从事软件项目管理、软件工程实施、数据库应用等领域的工作,在Windows操作系统下的应用软件编程方面有丰富的经验,另外对Oracle数据库的管理有深入的研究,是国内为数不多的OCM证书获得者之一。...

    FPGA入门:Verilog/VHDL语法学习的经验之谈

    总的来说,FPGA开发是一个从原理图到代码,再到IP核集成的复杂过程。理解并熟练运用Verilog或VHDL是这个过程中的关键步骤。通过不断地实践和学习,将代码与电路相结合,才能真正掌握HDL语言的精髓,从而在FPGA/CPLD...

    com本质论的英文版

    标题《com本质论的英文版》和描述提供的信息表明本文涉及的内容是...这本书不仅涵盖了COM的核心概念,还提供了大量的实际开发经验,对于想要在Windows平台上开发可复用组件的软件工程师来说,是一本宝贵的参考资料。

    浅谈用Protel 99 SE设计PCB板的技巧和注意事项.pdf

    在布局元器件时,需先确定PCB板的坐标原点,通常是以单板左边和下边的延长线交汇点或左下角的第一个焊盘为坐标原点。随后确定PCB的尺寸大小,最佳形状为矩形,长宽比为3:2或4:3。尺寸的选择需权衡电路性能和成本,...

    EMI-EMC入门与精通(电源系列)资料合集.zip

    EMC和EMI测试实践经验之谈 EMC基础知识---华为 EMC器件设计之GDT EMC器件设计之PTC热敏电阻 EMC器件设计之TVS EMC设计_防雷_浪涌、压敏电阻等.pdf EMC设计的3大规律和3大要素 EMC设计几个要点分享 EMC设计经典问题集...

    电源系列EMI-EMC入门开关电源EMI设计经验EMC详细的技术资料选型和应用技巧资料100个合集.zip

    EMC和EMI测试实践经验之谈.pdf EMC器件设计之GDT.pdf EMC器件设计之PTC热敏电阻.pdf EMC器件设计之TVS.pdf EMC基础知识---华为.pdf EMC整改方法.pdf EMC测试标准之雷击浪涌测试.pdf EMC的十个为什么.pdf EMC第二章-...

    电源设计开关电源设计电磁兼容电磁干扰EMI EMC设计资料大集合.zip

    EMC和EMI测试实践经验之谈.pdf EMC器件设计之GDT.pdf EMC器件设计之PTC热敏电阻.pdf EMC器件设计之TVS.pdf EMC基础知识---华为.pdf EMC整改方法.pdf EMC测试标准之雷击浪涌测试.pdf EMC的十个为什么.pdf EMC第二章-...

Global site tag (gtag.js) - Google Analytics