`
txswei
  • 浏览: 128624 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

出色软件工程师需懂的10个概念

阅读更多
    出色的软件工程师善用设计模式,勤于代码重构,编写单元测试,并对简单有宗教般的追求。除了这些,优秀的软件工程师还要通晓10个概念,这10个概念超越了编程语言与设计模式,软件工程师应当从更广的范围内明白这些道理。

  1. 关系数据库 (Relational Databases)
关系数据库因为在大规模 Web 服务上缺乏可扩充性而颇受微词,然而,关系数据库仍然是近20年来计算机技术中最伟大的成就。关系数据库对处理订单,公司数据方面有着出色的表现。

  关系数据库的核心是以记录表示数据,记录存放在数据库表,数据库使用查询语言(SQL)对数据进行搜索与查询,同时,数据库对各个数据表进行关联。

  数据库的标准化技术(normalization)讲的是使用正确的方式对数据进行分存以降低冗余,并加快存取速度。

  2. 安全 (Security)
  随着黑客的崛起与数据敏感性的上升,安全变得非常重要。安全是个广义的概念,涉及验证,授权与信息传输。

  验证是对用户的身份进行检查,如要求用户输入密码。验证通常需要结合 SSL (secure socket layer)进行;授权在公司业务系统中非常重要,尤其是一些工作流系统。最近开发的 OAuth 协议可以帮助 Web 服务将相应信息向相应用户开放。Flickr 便使用这种方式管理私人照片和数据的访问权限。

  另外一个安全领域是网络设防,这关系到操作系统,配置与监控。不仅网络危险重重,任何软件都是。Firefox 被称为最安全的浏览器,仍然需要频频发布安全补丁。要为你的系统编写安全代码就需要明白各种潜在的问题。

  3. 云计算 (Cloud Computing)
  RWW 最近的关于云计算的文章 Reaching For The Sky Through Compute Clouds 讲到了云计算如何改变大规模 Web 应用的发布。大规模的并行,低成本,与快速投入市场。

  并行算法发明以来,首先迎来的是网格计算,网格计算是借助空闲的桌面计算机资源进行并行计算。最著名的例子是 Berkley 大学的 SETI@home 计划,该计划使用空闲的 CPU 资源分析太空数据。金融机构也大规模实施网格计算进行风险分析。空闲的资源,加上 J2EE 平台的崛起,迎来了云计算的概念:应用服务虚拟化。就是应用按需运行,并可以随着时间和用户规模而实时改变。

  云计算最生动的例子是 Amazon 的 Web 服务,一组可以通过 API 进行调用的应用,如云服务(EC2),一个用来存储大型媒体文件的数据库(S3),索引服务(SimpleDB),序列服务(SQS)。

  4. 并发 (Concurrency)
  并发是软件工程师最容易犯错的地方,这可以理解,因为我们一直遵从线形思维,然而并发在现代系统中非常重要。

  并发是程序中的并行处理,多数现代编程语言包含内置的并发能力,在 Java,指的是线程。关于并发,最经典的例子是“生产/消费”模式,生产方生产数据和任务,并放入工作线程消费或执行。并发的复杂性在于,线程需要经常访问共同数据,每个线程都有自己的执行顺序,但需要访问共同数据。Doug Lea 曾写过一个最复杂的并发类,现在是 core Java 的一部分。

  5. 散列法(Hashing)
  Hashing 的目的是加速访问速度。如果数据是序列存储的,从中查询一个项的时间取决于数据列的大小。而散列法对每一个项计算一个数字作为索引,在一个好的 Hashing 算法下,数据查找的速度是一样的。

  除了存储数据,散列法对分布式系统也很重要。统一散列法(uniform hash )用来在云数据库环境下,在不同计算机之间分存数据。Google 的索引服务就是这种方法的体现,每一个 URL 都被散列分布到特定计算机。

  散列函数非常复杂,但现代类库中都有现成的类,重要的是,如何对散列法进行细调以获得最好的性能。

  6. 缓存(Caching)
  缓存对现代 Web 程序不可或缺,缓存是从数据库取回,并存放在内存中的数据。因为数据库直接存取的代价非常高,将数据从数据库取回并放在缓存中访问就变得十分必要。比如,你有一个网站,要显示上周的畅销书,你可以从数据将畅销书榜一次性取回放在缓存中,而不必在每次访问时都去数据库读数据。

  缓存需要代价,只有最常用的内容才可以放入缓存。很多现代程序,包括 Facebook,依靠一种叫做 Memcached 的分布式缓存系统,该系统是 Brad Firzpatrick 在工作于 LiveJournal 项目时开发的,Memcached 使用网络中空闲的内存资源建立缓存机制,Memcached 类库在很多流行编程语言,包括 Java 和 PHP 中都有。

    7. 算法的复杂性 (Algorithmic Complexity)
  关于算法的复杂性,软件工程师需要理解这样几件事。第一,大O标记法(big O notation);第二,你永远都不应该使用嵌套式循环(循环里面套循环),你应该使用 Hash 表,数组或单一循环;第三,如今优秀类库比比皆是,我们不必过分纠缠于这些库的效能的差别,我们以后还有机会进行细调;最后,不要忽视算法的优雅及性能,编写紧凑的,可读的代码可以让你的算法更简单,更干净。

  8. 惯例与模板 (Conventions and Templates)
  命名惯例和基础模板在编程模式中常被忽视,然而它可能是最强大的方法。命名惯例使软件自动化成为可能,如,Java Beans 框架在 getter 和 setter 方法中,使用简单的命名惯例。del.icio.us 网站的 URL 命名也使用统一的格式,如 http://del.icio.us/tag/software 会将用户带到所有标签为 software 的页。

  很多社会网络均使用简单命名,如,你的名字是 johnsmith ,那你的头像可能命名为 johnsmith.jpg,而你的 rss 聚合文件的命名很可能是 johnsmith.xml 。

  命名惯例还用于单元测试,如,JUnit 单元测试工具会辨认所有以 test 开头的类。

  我们这里说的模板(templates )指的并不是  C++ 或 Java 语言中的 constructs,我们说的是一些包含变量的模板文件,用户可以替换变量并输出最终结果。

  Cold Fusion 是最先使用模板的程序之一,后来,Java 使用 JSP 实现模板功能。Apache 近来为 Java 开发了非常好用的通用模板, Velocity。PHP 本身就是基于模板的,因为它支持 eval 函数。

  9. 分层 (Layering)
  用分层来讨论软件架构是最容易的。John Lakos 曾出版过一本关于大型 C++ 系统的书。Lakos 认为软件包含了层,书中介绍了层的概念,方法是,对每个软件组件,数一下它所依赖的组件数目就可以知道它的复杂程度。

  Lakos 认为,一个好的软件拥有金字塔结构,就是说,软件组件拥有层层积累的复杂度,但每个组件本身必须简单,一个优秀的软件包含很多小的,可重复使用的模块,每个模块有自己的职责。一个好的系统中,组件之间的依赖性不可交叉,整个系统是各种各样的组件堆积起来,形成一个金字塔。

  Lakos 在软件工程的很多方面都是先驱,最著名的是 Refactoring (代码重构)。代码重构指的是,在编程过程中需要不断地对代码进行改造以保证其结构的健壮与灵活。

  10. 界面(Interfaces)
  软件工程中最重要的概念是界面。任何软件都是一个真实系统的模型。如何使用简单的用户界面进行模型化至关重要。很多软件系统走这样的极端,缺乏抽象的冗长代码,或者过分设计而导致无谓的复杂。

  在众多软件工程书籍中,Robert Martin 写的《敏捷编程》值得一读。

  关于模型化,以下方法对你会有帮助。首先,去掉那些只有在将来才可能用得着的方法,代码越精练越好。第二,不要总认为以前的东西是对的,要善于改变。第三,要有耐心并享受过程。
  [点击查看文章来源]
1
2
分享到:
评论

相关推荐

    软件工程师不可不知的10个概念

    出色的软件工程师善用设计模式,勤于代码重构,编写单元测试,并对简单有宗教般的...除了这些,优秀的软件工程师还要通晓10个概念,这10个概念超越了编程语言与设计模式,软件工程师应当从更广的范围内明白这些道理。

    一位出色的软件工程师的6年总结

    以下,我们将结合一位出色软件工程师的六年总结,提炼出几点关键经验,它们对于刚步入职场的新手或是正处于发展中的工程师们具有极高的指导意义。 学历与能力之间,如何做到平衡至关重要。学历是过往学术成就的标志...

    软件工程师绩效考核.docx

    软件工程师绩效考核的考核标准包括以下几个方面: 1. 开发过程中,编码的水平:考核软件工程师在开发过程中的编码水平,包括编码的简洁性、规范性、注解的完整性等方面。 2. 开发过程中,相关技术文档的编写水平:...

    软件工程师日语.pdf

    本资源提供了软件工程师在实际工作中所需的日语知识,包括仕様書、语法、词汇、例句、实例、作业等方面的内容。 仕様書 在实际工作中,仕様書是一个非常重要的文档,它详细记录了软件的开发要求、测试流程、版本号...

    软件工程师的成长过程

    Servlet 开发是软件工程师的第十个学习阶段,包括 XML、Tomcat 服务器的安装使用操作、HTTP 协议简单理解、Servlet API 等知识点。这一阶段的学习可以帮助软件工程师掌握 Servlet 的基本知识。 第十一阶段:JSP ...

    软件工程师项目开发绩效考核表.pdf

    这份文件提供了一个软件工程师项目开发绩效考核表,旨在评估软件工程师在项目开发中的表现。该表格涵盖了多个方面,包括项目考核内容、代码复用性、Bug 严重程度、代码率、工作项目、专业复杂程度、工作量、工作主动...

    软件工程师面试评价表.pdf

    在当今这个信息化飞速发展的时代,软件工程师作为一种专业技术职位,是众多科技企业争相招聘的人才。为了选拔出最适合企业发展需要的软件工程师,企业往往会采用一系列严格的评价标准和流程。《软件工程师面试评价表...

    软件工程师必知的十个概念.pdf

    这份文件内容涉及到了软件工程师在工作中可能需要了解和掌握的多个重要技术概念和知识点。下面我将对这些概念进行详细解释: 1. 关系型数据库 (Relational Databases) 关系型数据库是基于关系模型的数据库管理系统...

    软件工程师认证 软件工程师考试大纲

    《软件工程师认证与软件工程师考试大纲》 软件工程师认证是对个人在软件开发领域专业技能的权威认可,...这样的考试设计旨在全面评估考生的理论知识和实践能力,确保他们具备成为一名合格软件工程师所需的专业素养。

    软考中级软件工程师复习材料

    理解这些概念并能灵活应用是合格软件工程师的基本素养。 三、设计与实现 在设计与实现部分,考生需要掌握常用的算法和数据结构,如排序算法、查找算法、树结构、图结构等,并能根据实际问题选择合适的设计模式。...

    计算机四级 软件工程师 必备

    计算机四级考试是针对软件工程师的一项专业能力评估,旨在测试考生在计算机科学与技术领域的理论知识、编程能力以及软件工程实践。对于准备参加此类考试的考生来说,了解并掌握相关知识点至关重要。以下是一些核心的...

    软件工程师+网络工程师+考试题解析

    在IT行业中,软件工程师和网络工程师是两个至关重要的角色,他们分别负责软件的开发与维护以及网络系统的构建和管理。为了提升自己的专业技能并获得相关认证,从业者常常需要通过一系列的考试来验证自己的知识水平。...

    se.rar_se 软件工程师_软件工程师

    "se.rar_se 软件工程师_软件工程师"这个标题暗示了这是一个与软件工程师相关的资源压缩包,可能包含了丰富的学习资料。描述中的“非常不错的软件工程师需要学习的知识点多学多健康”强调了软件工程师需要广泛学习,...

    工程师必懂:考验开关电源性能的“七个”概念!.docx

    本文主要讨论了考验开关电源性能的七个关键概念,包括纹波与噪声、调整率、LED 恒流驱动以及冲击电流。 首先,纹波和噪声是衡量开关电源质量的重要指标。纹波是指电源输出电压或电流中的周期性波动,它由低频纹波...

    java软件工程师简历模板

    Java软件工程师是信息技术行业中一个非常重要的角色,他们负责设计、编码、测试以及维护Java应用程序,以满足企业或组织的各种业务需求。在这个竞争激烈的市场中,一份精心制作的简历是求职者打开成功之门的关键。本...

    软件工程师不可不知道的10个概念

    程师必须了解的一个核心概念是...软件工程师在实际工作中需要不断学习和应用这些概念,以提升软件的质量、性能和安全性。同时,随着技术的发展,新的概念和工具也会不断涌现,持续学习和适应新技术是保持竞争力的关键。

    软件工程师不可不知的10个概念.pdf

    在讨论《软件工程师不可不知的10个概念》时,我们必须将重点放在几个核心的IT和软件工程领域,以及它们对软件开发的深远影响。 1. 关系型数据库(Relational Databases): 关系型数据库是数据存储和管理的基石。...

Global site tag (gtag.js) - Google Analytics