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

改善程序代码质量的一些技巧

阅读更多

有很多理由都能说明为什么我们应该写出清晰、可读性好的程序。最重要的一点,程序你只写一次,但以后会无数次的阅读。当你第二天回头来看你的代码 时,你就要开始阅读它了。当你把代码拿给其他人看时,他必须阅读你的代码。因此,在编写时多花一点时间,你会在阅读它时节省大量的时间。

让我们看一些基本的编程技巧:
    尽量保持方法简短
    尽管很多人都遵循这个规则,但它仍然非常的重要。你写的方法要始终能在一个屏幕里放得下。如果你需要去滚动屏幕,这会分散你的注意力,而且你看不到 整个的上下文。最佳长度是5-20行,这根据你的情况而定。当然,getters/setters 通常是一行代码的方法,但与其说它们是真正的方法,不如说它们只是存取工具。
    永远永远不要把同一个变量用于多个不同的目的
    一个变量应该始终只为一个目的服务。通过使变量常量化(C++里的const, Java里的final),使得编译器能够优化编译,而且使你的代码醒目表达这个变量是不能改变的,你的程序的可读性会变得更好。
    使用自描述的变量名和方法名
    你的代码应该,对于任何人来说,只要看一眼就能知道是干嘛的。尽量不要用简写方式,除非有特殊的习惯,就像下面的:

 

    	src - source
    	pos - position
    	prev - previous

   如果你认为描述性的名称并不是那么有价值,请对比一下n, ns, nsisd 和 numTeamMembers, seatCount, numSeatsInStadium。

    尽可能的把变量定义在靠近使用它的地方
    盖房子时,你可不希望把锤子放到别人的院子里。你希望把它们放的离手头越近越好。定义变量也是同样的道理。

 

    	int foo = 3;
    	int bar = 5;
    	// 一大段使用"bar"的代码,
    	// 但没用到"foo"
    	// ... 	 
    	baz(foo);

 

这段代码可以简单的重构成

 

    	int bar = 5;
    	// 一大段使用"bar"的代码,
    	// 但没用到"foo"
    	// ...    	 
    	int foo = 3;
    	baz(foo);

 当你把变量的声明和第一次用到它的地方间隔太远时(距离超过一个屏幕),这确实会成为一个问题。记住上下文关系会变得困难,你需要滚动屏幕去找哪来的这个变量。

    拒绝神秘数字

    当你要把什么东西跟一个常量值做比较时,记得把这个值定义成常量。没有什么会比去猜测你的同事写的这样的代码更让人头疼的事了:

        il < 4384
    换个形式感觉如何?
        inputLength < MAX_INPUT_LENGTH
    友好的对待你的语言

学习新语言是一种很有乐趣的事情,你能学到一种新的完成任务的途径。当一个对一种语言已经很专业的人去学习另一种语言时,会出现一种很大的负面效应。比如说你是一个Java开发者,试图去学习Ruby。你应该学会用Ruby的方式解决问题,而不是沿用Java的解决问题的思想。
    当你需要重复5遍"Hello world!"时,在Java里,你可能会这样做:
        for (int i = 0; i < 5; i++) {
            System.out.println("Hello world!");
        }
    在Ruby里,你也许会禁不住这样写:
        for i in (0..5)
          puts "Hello world!"
        end
    这样看起来没问题,但有一个更好的方式:
        5.times { puts "Hello world!" }
    不要逆常规而行
    每种语言都有自己不同的习俗约定。一般来说,人们听的最多的是Java的编码规范。让我们看看其中的一些习俗规范:
        方法名应该小写字母开头,其后用字母大写的单词连接(veryLongVariableName)
        类名应该都使用首字母大写的单词连接而成
        常量名应该全部大写,用下划线连接(MY_CONSTANT)
        左大括号应该跟 if 语句在同一行
    只有在有必要的理由时才去打破这些常规,不要轻易的因为你不高兴就违反它。如果你只是在团队里改变一些这样的习惯,那也没问题,但当把你代码拿出来和其他的没有这些思想准备的程序员共享时,问题就会来了。
    警惕过早优化
    过早优化是所有问题的根源,至少电视上是这么说的 … 你第一应该关心的事情是写出易于理解的代码。起初写的程序不要求快。除非你的程序很慢,否则谈优化都是为时太早。如果你想优化什么东西,你首先需要知道问题出在哪。这就是我们需要profilers这个工具的原因。
    在没有知道问题在哪的情况下试图对程序进行优化,其结果必然是把程序能坏,至少你的代码会丧失可读性。如果你觉得有些地方很慢,不要盲目的重写代码,你应先找到慢的证据。不要傻乎乎的去解决根本不存在的问题。
    积极重构测试过的程序
    没有任何东西会是完美的。即使你感觉你真正写出了一段完美的代码,几个月后回头再看看,你可能会惊讶道"怎么会这样傻?"
    改进程序的一个好方法就是重构,但要等程序测试通过之后。你首先要确保程序是好的可运行的,你可以通过自动化测试或手工测试完成这个工作。
   之初,你需要的是程序可用。不要期望在第一次就写出完美的程序,你只需要把它写出来,可用。然后重构它,使之完美。对于你们当中知道测试驱动开发 (TDD)的人来说,对这个会很熟悉。这里的关键就在于你要习惯于重构这种事情。如果你使用的是像IntelliJ IDEA这样强大的集成开发工具的话,重构的工作会变得简单的多。
  重构之后,你也许会弄出一些Bug,导致某些功能出问题。这就是为什么说写自动化测试的原因。不论何时重构后,只要运行一下所有的测试用例,你就能准确的知道什么地方出了问题。
    不要过度沉迷于技巧
    当我第一次读到有关设计模式的知识时,我觉得我找到了圣杯。这些精心设计的思想作用显著,它能使你的设计易于理解,因为你可以简单的说"我使用的是 '观察器模式'",而不用从头到尾的解释一遍。那么,有问题吗?一切看起来都这么自然、简单,你开始不论在哪都使用设计模式。为什么不把这个类做成 singleton呢?干嘛不去再创建一些工厂类呢?
    于是一个80行就能写完的脚本,你最终使用了10个类,15个接口,外加一大堆范式和标记符。97%的代码不做任何事情。设计模式是一种十分有用的用来简化你的设计的工具,但这不意味着你该在所有能用到的地方都用它。你应该用它们,但不能滥用。
    通过习例学习新知
    编程是一种学习新知的过程。当你学到了新的程序库或新语言,你可能会迫不及待的丢掉旧的代码,用你新学到的东西重新写一遍。有很多的理由都能说明你不该这么做。
    往现有的应用里增加新的类库或框架同属于这种情况。就说你写了一个Javascript的web应用,期间,你发现了jQuery。现在你突然急切的想丢到你的Javascript程序,重新用jQuery写,尽管你还从来没用过它。
    最好的方式是你先用jQuery写一些简单的例子,通过这种方式把你在应用里将要用到的知识都学会。需要AJAX?在你的项目之外做一些小例子,当完全弄懂了后,丢掉例子,应用到你的产品里。
如果你非常关注编程技术,我强烈的推荐你阅读Steve McConnell写的 《代码大全》 一书。它会永远的改变你对编程的认识。:)

分享到:
评论

相关推荐

    马伟-编写高质量代码 改善C程序代码的125个建议(带索引书签目录高清扫描版).pdf

    本书从C语言语法和C11标准2个方面深入探讨了编写高质量C代码的技巧与禁忌, 一共总结出125条宝贵的建议。每一个建议对应C程序员可能会遇到的一类问题, 不仅以建议的方式从正反两面给出了实践证明为十分优秀的解决方案...

    编写高质量代码:改善C程序代码的125个建议

    马伟的《编写高质量代码(改善C程序代码的 125个建议)》是华章“编写高质量代码”系列的第7本,之前已经出版C++、C#、Java、Pvthon、 ObjectiVe-c、Javascript相关*作。在通往“C语 言技术殿堂”的路上,本书将为你...

    编写高质量代码:改善C++程序的150个建议

    关于一些编程的小技巧,对于C/C++程序员的编程有参考价值。挺不错的。

    编写高质量代码改善C#程序——使用泛型集合代替非泛型集合(建议20)

    主要介绍编写高质量的代码有助于改善C#程序,在开发过程中集合用的比较多,如何把集合使用好,在开发过程必须掌握的技巧,下面这篇文章就给大家详细介绍编写高质量代码改善C#程序——使用泛型集合代替非泛型集合...

    [源代码] ASP.NET 3.5 电子商务网站开发全程解析

    [源代码] [程序运行说明]"&gt;★ 程序说明:★ ☆ 项目介绍:☆ 《ASP NET 电子商务开发实战》是 Amazon 超级畅销图书 学习 ASP NET 电子商务网站开发的必备参考书 真实案例 实战技巧 让你即学即用; 《ASP NET ...

    Oracle SQL高级编程(资深Oracle专家力作,OakTable团队推荐)--随书源代码

     在程序中优化查询而无需改动代码。  作为Oracle SQL经典著作之一,本书为SQL开发人员指明了前行的方向,赋予了他们不断开拓的动力。 作者简介  KAREN MORTON 研究人员、教育家及顾问,Fidelity信息服务公司...

    Node.js-Tips-Tricks-and-Techniques:Node.js

    您将增强自己的编码风格,了解Node.js流程,并提高代码质量。 本课程分为6个部分,涉及Node.js的特定方面,并着重于发现Node.js的新可能性以增强您的当前技能。 在本课程结束时,您将学习一些有关Node.js Web开发的...

    神性2原罪:维基技巧弹出「Divinity 2 Original Sin: Wiki Skill Popup」-crx插件

    我没有找到一种简单的方法来浏览技能说明,尤其是对于新手来说,这是一种生活质量的改善。 注意:此扩展使用jQuery和jQuery hoverIntent插件。 可以在这里找到源代码:...

    asp.net知识库

    HttpModule 实现 ASP.Net (*.aspx) 中文简繁体的自动转换,不用修改原有的任何代码,直接部署即可! 服务器自定义开发二之客户端脚本回发 Web开发: 使用URL重写WEB主题切换 如何在Asp.Net1.1中实现页面模板(所谓的...

    Pro .NET Best Practices .net最佳实践 英文版

    第6章涵盖.NET规章制度标准和指南,识别并避免“代码异味”的技巧。第7章以非常规的方式来重新审视C#语言,带给你全新体验。第8章分享了多个符合高效开发原则的测试代码改进方法。第9章介绍生成自动化,以消除易错...

    《.NET最佳实践》.((美)Stephen Ritchie)

    第6章涵盖.NET规章制度标准和指南,识别并避免“代码异味”的技巧。第7章以非常规的方式来重新审视C#语言,带给你全新体验。第8章分享了多个符合高效开发原则的测试代码改进方法。第9章介绍生成自动化,以消除易错...

    VC++数字图像处理与工程应用

    20世纪20年代,图像处理首次应用于改善伦敦和纽约之间通过海底电缆传送的图片质量。经过几十年的研究与发展,数字图像处理的理论和方法进一步完善,应用领域更加广阔,已经成为一门新兴的学科,并在向更高级的方向...

    软件框架设计的艺术

    3.9 如何检查API的质量 37 3.9.1 可理解性 37 3.9.2 一致性 38 3.9.3 可见性 39 3.9.4 简单的任务应该有简单的方案 40 3.9.5 保护投资 40 第4章 不断变化的目标 42 4.1 第一个版本远非完美 ...

Global site tag (gtag.js) - Google Analytics