`
xiebh
  • 浏览: 613920 次
  • 性别: Icon_minigender_1
  • 来自: 太原
社区版块
存档分类
最新评论

作一个真正合格的程序员(引用)

阅读更多
该文引自:http://www.blogjava.net/hadeslee/archive/2007/09/06/143192.html

作为一个真正合格的程序员,或者说就是可以真正合格完成一些代码工作的程序员,应该具有的素质。
1:团队精神和协作能力
把它作为基本素质,并不是不重要,恰恰相反,这是程序员应该具备的最基本的,也是最重要的安身立命之本。任何个人的力量都是有限的,即便如linus 这样的天才,也需要通过组成强大的团队来创造奇迹,那些遍布全球的为linux写核心的高手们,没有协作精神是不可想象的。一旦进入系统的研发团队,进入 商业化和产品化的开发任务,缺乏这种素质的人是不合格的。
2:文档习惯
说高水平程序员从来不写文档的肯定是乳臭未干的毛孩子,良好的文档是正规研发流程中非常重要的环节,作为代码程序员,30%的工作时间写技术文档是很 正常的,而作为高级程序员和系统分析员,这个比例还要高很多。缺乏文档,一个软件系统就缺乏生命力,在未来的查错,升级以及模块的复用时就都会遇到极大的 麻烦。
3:规范化,标准化的代码编写习惯
代码的变量命名,代码内注释格式,甚至嵌套中行缩进的长度和函数间的空行数字都有明确规定,良好的编写习惯,不但有助于代码的移植和纠错,也有助于不 同技术人员之间的协作。有些coding fans叫嚣高水平程序员写的代码旁人从来看不懂,这种叫嚣只能证明他们自己?根不配自称程序员。代码具有良好的可读性,是程序员基本的素质需求。没有规 范化和标准化的代码习惯,研发之间的协作是绝对不可想的。
4:需求理解能力
程序员需要理解一个模块的需求,很多程序员写程序往往只关注一个功能需求,他们把性能指标全部归结到硬件,操作系统和开发环境上,而忽视了本身代码的 性能考虑,性能需求指标中,稳定性,并访支撑能力以及安全性都很重要,作为程序员需要评估该模块在系统运营中所处的环境,将要受到的负荷压力以及各种潜在 的危险和恶意攻击的可能性。就这一点,一个成熟的程序员至少需要2到3年的项目研发和跟踪经验才有可能有心得。
5:复用性,模块化思维能力
经常可以听到一些程序员有这样的抱怨,写了几年程序,变成了熟练工,每天都是重复写一些没有任何新意的代码,这其实是中国软件人才最大浪费的地方,一 些重复性工作变成了熟练程序员的主要工作,而这些,其实是完全可以避免的。复用性设计,模块化思维就是要程序员在完成任何一个功能模块或函数的时候,要多 想一些,不要局限在完成当前任务的简单思路上,想想看该模块是否可以脱离这个系统存在,是否可以通过简单的修改参数的方式在其他系统和应用环境下直接引 用,这样就能极大避免重复性的开发工作,如果一个软件研发单位和工作组能够在每一次研发过程中都考虑到这些问题,那么程序员就不会在重复性的工作中耽误太 多时间,就会有更多时间和精力投入到创新的代码工作中去。一些好的程序模块代码,即便是70年代写成的,拿到现在放到一些系统里面作为功能模块都能适合的 很好,而现在很多软件一升级或改进就动辄全部代码重写,大部分重复性工作无谓的浪费了时间和精力,这是我们应当刻意克服的弊病。
6:测试习惯
作为一些正规化的开发而言,专职的测试工程师是不可少的,但是并不是说有了专职的测试工程师程序员就可以不进行自测;软件研发作为一项工程而言,一个 很重要的特点就是问题发现的越早,解决的代价就越低,程序员在每段代码,每个子模块完成后进行认真的测试,就可以尽量将一些潜在的问题最早的发现和解决, 这样对整体系统建设的效率和可靠性就有了最大的保证。测试工作实际上需要考虑两方面,一方面是正常调用的测试,也就是看程序是否能在正常调用下完成基本功 能,这是最基本的测试职责,可惜在很多公司这成了唯一的测试任务,实际上还差的远那;第二方面就是异常调用的测试,比如高压力负荷下的稳定性测试,用户潜 在的异常输入情况下的测试,整体系统局部故障情况下该模块受影响状况的测试,频发的异常请求阻塞资源时的模块稳定测试等等。当然并不是程序员要对自己的每 段代码都需要进行这种完整测试,但是程序员必须清醒认识自己的代码任务在整体项目中的地位和各种性能需求,有针对性的进行相关测试并尽早发现和解决问题, 当然这需要上面提到的需求理解能力。
7:学习和总结的能力
程序员是人才很容易被淘汰,很容易落伍的职业,因为一种技术可能仅仅在三两年内具有领先性,程序员如果想安身立命,就必须不断跟进新的技术,学习新的 技能。善于学习,对于任何职业而言,都是前进所必需的动力,对于程序员,这种要求就更加高了。但是学习也要找对目标,善于总结,也是学习能力的一种体现, 每次完成一个研发任务,完成一段代码,都应当有目的的跟踪该程序的应用状况和用户反馈,随时总结,找到自己的不足,这样逐步提高,一个程序员才可能成长起 来。  
具备以上全部素质的人,应当说是够格的程序员了,请注意以上的各种素质都不是由IQ决定的,也不是大学某些课本里可以学习到的,需要的仅仅是程序员对自己工作的认识,是一种意识上的问题。

高级程序员,以至于系统分析员,也就是对于一个程序项目的设计者而言,除了应该具备上述全部素质之外,需具备以下素质:
第一,需求分析能力
对于程序员而言,理解需求就可以完成合格的代码,但是对于研发项目的组织和管理者,他们不但要理解客户需求,更多时候还要自行制定一些需求,为什么这 么说呢?一般而言,进行研发任务,也许是客户提出需求,也许是市场和营销部门提出的需求,这时候对于研发部门,他们看到的不是一个完整的需求,通常而言, 该需求仅仅是一些功能上的要求,或者更正规些,可能获得一个完整的用户视图;但是这都不够,因为客户由于非技术因素多一些,他们可能很难提出完整和清晰, 或者说专业性的性能需求,但是对于项目组织者和规划者,他必须能够清醒认识到这些需求的存在并在完成需求分析报告的时候适当的提出,同时要完整和清晰的体 现在设计说明书里面,以便于程序员编码时不会失去这些准则。程序设计者必须正确理解用户需求所处的环境,并针对性做出需求的分析,举例而言,同样一个软件 通过ASP租用方式发布和通过License方式发布,性能需求可能就是有区别的,前者强调的是更好的支撑能力和稳定性,而后者则可能更强调在各种平台下 的普适性和安装使用的简捷性。
第二,项目设计方法和流程处理能力
程序设计者必须能够掌握不少于两到三种的项目设计方法(比如自顶至下的设计方法,比如快速原型法等等),并能够根据项目需求和资源搭配来选择合适的设 计方法进行项目的整体设计。设计方法上选择不当,就会耽误研发周期,浪费研发资源,甚至影响研发效果。一个程序设计者还需要把很多功夫用在流程图的设计和 处理上,他需要做数据流图以确立数据词典;他需要加工逻辑流图以形成整体的系统处理流程。一个流程有问题的系统,就算代码多漂亮,每个模块多精致,也不会 成为一个好的系统。当然,做好流程分析并选择好项目设计方法,都需要在需求分析能力上具有足够的把握。
第三,复用设计和模块化分解能力
这个似乎又是老调重谈,前面基本素质上不是已经说明了这个问题吗?作为一个从事模块任务的程序员,他需要对他所面对的特定功能模块的复用性进行考虑, 而作为一个系统分析人员,他要面对的问题复杂的多,需要对整体系统按照一种模块化的分析能力分解为很多可复用的功能模块和函数,并针对每一模块形成一个独 立的设计需求。举个例子,好比是汽车生产,最早每辆汽车都是独立安装的,每个部件都是量身定做的,但是后来不一样了,机器化大生产了,一个汽车厂开始通过 流水线来生产汽车,独立部件开始具有一定的复用性,在后来标准化成为大趋势,不同型号,品牌甚至不同厂商的汽车部件也可以进行方便的换装和升级,这时候, 汽车生产的效率达到最大化。软件工程也是同样的道理,一个成熟的软件行业,在一些相关项目和系统中,不同的部件是可以随意换装的,比如微软的许多桌面软 件,在很多操作模块(如打开文件,保存文件等等)都是复用的同一套功能模块,而这些接口又通过一些类库提供给了桌面应用程序开发者方便挂接,这就是复用化 的模块设计明显的一个佐证。将一个大型的,错综复杂的应用系统分解成一些相对独立的,具有高度复用性的,并能仅仅依靠几个参数完成数据联系的模块组合,是 作为高级程序员和系统分析员一项最重要的工作,合适的项目设计方法,清晰的流程图,是实现这一目标的重要保证。
第四,整体项目评估能力
作为系统设计人员,必须能够从全局出发,对项目又整体的清醒认识,比如公司的资源配置
是否合理和到位,比如工程进度安排是否能最大化体现效率又不至于无法按期完成。评估项目整体和各个模块的工作量,评估项目所需的资源,评估项目可能遇到的 困难,都需要大量的经验积累,换言之,这是一种不断总结的累计才能达到的境界。在西方一些软件系统设计的带头人都是很年长的,比如4,50岁,甚至更老, 他们在编码方面已经远远不如年轻人那么活络,但是就项目评估而言,他们几十年的经验积累就是最重要和宝贵的财富。中国缺这么一代程序员,主要还不是缺那种 年纪的程序员,而是那种年纪的程序员基本上都是研究单位作出来的,都不是从专业的产品化软件研发作出来的,他们没有能积累那种产品化研发的经验,这也是没 有办法的事情。
第五,团队组织管理能力
完成一个项目工程,需要团队的齐心协力,作为项目设计者或研发的主管人,就应当有能力最大化发挥团队的整体力量,技术管理由于其专业性质,不大同于一般的人事管理,因为这
里面设计了一些技术性的指标和因素。首先是工作的量化,没有量化就很难做到合适的绩效考核,而程序量化又不是简单的代码行数可以计算的,因此要求技术管理 人员需要能真正评估一个模块的复杂性和工作量。其次是对团队协作模式的调整,一般而言,程序开发的协作通常分为小组进行,小组有主程序员方式的,也有民主 方式的,根据程序员之间的能力水平差距,以及根据项目研发的需求,选择合适的组队方式,并能将责权和成员的工作任务紧密结合,这样才能最大发挥组队的效 率。一个代码水平高的人,未必能成为一个合格的项目研发主管,这方面的能力欠缺往往是容易被忽视的。
综上可以看到,作为一个主管研发的负责人,一个项目设计者,所需要具备的素质和能力并不是程序代码编写的能力,当然一般情况下,一个程序员通过不断的 总结提高达到了这种素质的时候,他所具有的代码编写能力也已经相当不简单了,但是请注意这里面的因果关系,一个高水平的项目设计者通常已经是代码编写相当 优秀的人了,但是并不是一个代码相当优秀的程序员就可以胜任项目设计的工作,这里面存在的也不是智商和课本的问题,还是在于一个程序员在积累经验,逐步提 升的时候没有意识到应当思考哪方面的东西,没有有意识的就项目的组织和复用设计进行揣摩,没有经常性的文档习惯和总结习惯,不改变这些,我们的合格的项目 设计者还是非常欠缺。

分享到:
评论

相关推荐

    JAVA六大问题程序员必须知道--在此给予详解

    这意味着`s`本身并不是一个对象,而是一个引用,它指向内存中的某个位置,该位置存储着真正的`String`对象。 进一步地,如果执行以下代码: ```java String string = s; ``` 这里我们声明了一个新的引用`string`...

    C#初级教程(.net程序员不再是梦想)

    C#是一种广泛应用于软件开发的面向对象的编程语言,...只有不断编写代码,解决实际问题,你才能真正掌握C#,成为一名合格的.NET程序员。在这个过程中,这个初级教程会是你宝贵的指南,引领你进入精彩纷呈的C#编程世界。

    面向对象程序设计的概念PPT课件.pptx

    它们用于将一个数据类型转换为另一个数据类型,但应谨慎使用,因为可能导致精度损失或意外行为。 6. 结构体与枚举类型: 结构体是自定义数据类型,可以包含多种类型的成员。枚举类型则定义一组具有特定名字的整数...

    大厂京东Java实习生面试真题

    首先,如果对象重写了`finalize()`方法且未被执行过,那么会将其放入一个队列等待执行。如果`finalize()`执行后对象仍然无法被引用,才会被真正回收。 2. **字符编码**: - ASCII编码是最基础的编码方式,用1个...

    《C++程序设计》教程课件

    此外,C++还支持模板和STL(Standard Template Library),这是C++的一个强大工具。模板可以创建泛型代码,提高代码的复用性,而STL包括了容器(如vector、list、set等)、算法和迭代器,为开发者提供了高效、便捷的...

    c大学教程源代码

    通过研究这些源代码,不仅可以理解C语言的逻辑和流程,还可以学习到良好的编程习惯和风格,这对于成为一个合格的C程序员至关重要。因此,对于任何想要深入学习C语言的人来说,【C大学教程源代码】都是一个不可或缺的...

    C语言头文件库

    "C语言头文件库"是一个集合了C语言所有标准头文件的资源库,方便开发者在编写程序时进行引用和使用。 1. **头文件的作用** 头文件的主要作用是为源代码提供预编译的声明,使得编译器可以在编译阶段知道函数的原型...

    面试经典大全

    6. **错误与调试**:学会分析和处理运行时错误,如段错误、空指针引用等,以及使用调试工具(如GDB)进行调试,是每一个合格的C程序员必备的技能。 7. **标准库与系统调用**:熟悉C标准库(如stdio、stdlib、string...

    c#给学员的笔记(三) ASP.NET

    以下是一个使用`Format`方法的例子,展示了如何构建动态的字符串输出: ```csharp string myString = string.Format("{0} 乘以 {1} 等于 {2}", 2, 3, 2 * 3); ``` 这将生成字符串"2 乘以 3 等于 6",其中"{0}"、"{1}...

    编程新手真言绝对实用

    3. **计算机学生专业课程本质讲解**:计算机科学专业的课程不仅涵盖了编程技能,还包括算法、数据结构、计算机组成原理等多个方面,这些都是成为合格程序员的基础。 4. **用C++进行开发要学到什么程度**:C++是一门...

    c语言经典题目.rar

    10. **错误处理和调试**:理解并处理运行时错误,学会使用调试工具,这对于成为一名合格的C语言程序员是必不可少的。 通过解答这100个实例,学习者不仅能掌握C语言的基本知识,还能锻炼解决问题的能力,为以后的...

    JAVA简单应用编程140例

    这些基础知识是所有JAVA程序的基础,理解并熟练运用它们是成为一名合格JAVA程序员的第一步。 **2. 面向对象编程** JAVA是一种面向对象的语言,实例中会详细介绍类、对象、封装、继承、多态等面向对象的基本概念。...

    java语言结构初步

    理解这些概念是成为合格Java程序员的基础。 首先,让我们详细了解一下Java的基本结构: 1. **数据类型**:Java有两大类数据类型——基本类型和引用类型。基本类型包括整型(byte, short, int, long)、浮点型...

    学习C++朋友的50条建议

    了解并避免C++中常见的错误,如内存泄漏、空指针解引用等,是成为合格C++程序员的必要条件。 #### 50. 享受编程的乐趣 最后但同样重要的是,享受编程的过程。只有真正热爱它,才能持续不断地进步。 以上建议涵盖了...

    Python闭包思想与用法浅析

    `make_adder` 返回 `adder` 函数的一个引用,该引用可以在外部调用。 #### 三、闭包的应用场景 1. **惰性求值**:闭包可以用于实现惰性求值,即只有在真正需要结果时才计算结果。这种机制可以提高程序效率,避免...

    Fourth_lesson

    3. **继承**:Java支持单一继承,即一个类只能直接继承自一个父类。这通过关键字`extends`实现。继承有助于代码重用和构建类的层次结构。 4. **多态**:多态性允许不同类的对象对同一消息做出不同的响应。Java通过...

    深入理解Android:卷I--详细书签版

    5.3.1 一个变量引发的思考 109 5.3.2 常用同步类 114 5.4 Looper和Handler类分析 121 5.4.1 Looper类分析 122 5.4.2 Handler分析 124 5.4.3 Looper和Handler的同步关系 127 5.4.4 HandlerThread介绍 129 5.5...

Global site tag (gtag.js) - Google Analytics