`

改良程序的11技巧 装载

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

让我们看一些基本的编程技巧:

   1. 尽量保持方法简短
   2. 永远永远不要把同一个变量用于多个不同的目的
   3. 使用自描述的变量名和方法名
   4. 尽可能的把变量定义在靠近使用它的地方
   5. 拒绝神秘数字
   6. 友好的对待你的语言
   7. 不要逆常规而行
   8. 警惕过早优化
   9. 积极重构测试过的程序
  10. 不要过度沉迷于技巧
  11. 通过习例学习新知

现在,让我们把每个小点展开来详细讲一下。
1. 尽量保持方法简短

尽管很多人都遵循这个规则,但它仍然非常的重要。你写的方法要始终能在一个屏幕里放得下。如果你需要去滚动屏幕,这会分散你的注意力,而且你看不到 整个的上下文。最佳长度是5-20行,这根据你的情况而定。当然,getters/setters 通常是一行代码的方法,但与其说它们是真正的方法,不如说它们只是存取工具。
2. 永远永远不要把同一个变量用于多个不同的目的

一个变量应该始终只为一个目的服务。通过使变量常量化(C++里的const, Java里的final),使得编译器能够优化编译,而且使你的代码醒目表达这个变量是不能改变的,你的程序的可读性会变得更好。
3. 使用自描述的变量名和方法名

你的代码应该,对于任何人来说,只要看一眼就能知道是干嘛的。尽量不要用简写方式,除非有特殊的习惯,就像下面的:

src - source
pos - position
prev - previous

如果你认为描述性的名称并不是那么有价值,请对比一下n, ns, nsisd 和 numTeamMembers, seatCount, numSeatsInStadium。
4. 尽可能的把变量定义在靠近使用它的地方

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

int foo = 3;
int bar = 5;
// 一大段使用“bar”的代码,
// 但没用到“foo”
// ...

baz(foo);

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

int bar = 5;
// 一大段使用“bar”的代码,
// 但没用到“foo”
// ...

int foo = 3;
baz(foo);

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

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

il < 4384

换个形式感觉如何?

inputLength < MAX_INPUT_LENGTH

6. 友好的对待你的语言

学习新语言是一种很有乐趣的事情,你能学到一种新的完成任务的途径。当一个对一种语言已经很专业的人去学习另一种语言时,会出现一种很大的负面效应。比如说你是一个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!" }

7. 不要逆常规而行

每种语言都有自己不同的习俗约定。一般来说,人们听的最多的是Java的编码规范。让我们看看其中的一些习俗规范:

    * 方法名应该小写字母开头,其后用字母大写的单词连接(veryLongVariableName)
    * 类名应该都使用首字母大写的单词连接而成
    * 常量名应该全部大写,用下划线连接(MY_CONSTANT)
    * 左大括号应该跟 if 语句在同一行

只有在有必要的理由时才去打破这些常规,不要轻易的因为你不高兴就违反它。如果你只是在团队里改变一些这样的习惯,那也没问题,但当把你代码拿出来和其他的没有这些思想准备的程序员共享时,问题就会来了。
8. 警惕过早优化

过早优化是所有问题的根源,至少电视上是这么说的 … 你第一应该关心的事情是写出易于理解的代码。起初写的程序不要求快。除非你的程序很慢,否则谈优化都是为时太早。如果你想优化什么东西,你首先需要知道问题出在哪。这就是我们需要profilers这个工具的原因。

在没有知道问题在哪的情况下试图对程序进行优化,其结果必然是把程序能坏,至少你的代码会丧失可读性。如果你觉得有些地方很慢,不要盲目的重写代码,你应先找到慢的证据。

不要傻乎乎的去解决根本不存在的问题。
9. 积极重构测试过的程序

没有任何东西会是完美的。即使你感觉你真正写出了一段完美的代码,几个月后回头再看看,你可能会惊讶道”怎么会这样傻?“

改进程序的一个好方法就是重构,但要等程序测试通过之后。你首先要确保程序是好的可运行的,你可以通过自动化测试或手工测试完成这个工作。

之初,你需要的是程序可用。不要期望在第一次就写出完美的程序,你只需要把它写出来,可用。然后重构它,使之完美。对于你们当中知道测试驱动开发 (TDD)的人来说,对这个会很熟悉。这里的关键就在于你要习惯于重构这种事情。如果你使用的是像IntelliJ IDEA这样强大的集成开发工具的话,重构的工作会变得简单的多。

重构之后,你也许会弄出一些Bug,导致某些功能出问题。这就是为什么说写自动化测试的原因。不论何时重构后,只要运行一下所有的测试用例,你就能准确的知道什么地方出了问题。
10. 不要过度沉迷于技巧

当我第一次读到有关设计模式的知识时,我觉得我找到了圣杯。这些精心设计的思想作用显著,它能使你的设计易于理解,因为你可以简单的说”我使用的是 ‘观察器模式’“,而不用从头到尾的解释一遍。那么,有问题吗?一切看起来都这么自然、简单,你开始不论在哪都使用设计模式。为什么不把这个类做成 singleton呢?干嘛不去再创建一些工厂类呢?

于是一个80行就能写完的脚本,你最终使用了10个类,15个接口,外加一大堆范式和标记符。97%的代码不做任何事情。设计模式是一种十分有用的用来简化你的设计的工具,但这不意味着你该在所有能用到的地方都用它。你应该用它们,但不能滥用。
11. 通过习例学习新知

编程是一种学习新知的过程。当你学到了新的程序库或新语言,你可能会迫不及待的丢掉旧的代码,用你新学到的东西重新写一遍。有很多的理由都能说明你不该这么做。

往现有的应用里增加新的类库或框架同属于这种情况。就说你写了一个Javascript的web应用,期间,你发现了jQuery。现在你突然急切的想丢到你的Javascript程序,重新用jQuery写,尽管你还从来没用过它。

最好的方式是你先用jQuery写一些简单的例子,通过这种方式把你在应用里将要用到的知识都学会。需要AJAX?在你的项目之外做一些小例子,当完全弄懂了后,丢掉例子,应用到你的产品里。

如果你非常关注编程技术,我强烈的推荐你阅读Steve McConnell写的 《代码大全》 一书。它会永远的改变你对编程的认识。:)
从开源社区复制的,
分享到:
评论

相关推荐

    用C语言设计程序实现多页程序的引导装载.pdf

    "用C语言设计程序实现多页程序的引导装载" 本文介绍了使用C语言设计程序实现多页程序的引导装载,解决TMS320VC5000系列DSP上电时需要通过掩膜在DSP片上ROM的bootloader程序完成对用户主程序的引导装载的问题。由于...

    Ti3559开发板引导装载程序

    【Ti3559开发板引导装载程序】是针对德州仪器(Texas Instruments,简称TI)的处理器OMAP-L138或C6748(代号为Ti3559)的一种定制化引导加载程序。这个开发板主要用于嵌入式系统设计,常见于工业控制、图像处理和...

    汇编程序与代码块装载

    在深入探讨汇编程序与代码块装载之前,我们首先需要理解CPU的工作原理和汇编语言的基础。CPU,即中央处理器,是计算机的核心组件,负责解释和执行计算机指令。x86系列CPU,由Intel和AMD制造,是目前PC机和Mac机上...

    c# 在内存中装载并运行程序或程序集

    在.NET框架中,C#语言提供了强大的能力,允许开发者在内存中装载并运行程序或程序集,这在某些场景下非常有用,例如动态加载、测试、插件系统等。这个特性主要通过System.Reflection命名空间中的类来实现。下面将...

    滚动轴承 通用装载轴承用改良参考额定寿命的计算方法

    根据给定文件信息,本文将详细介绍ISO国际标准中关于滚动轴承通用装载轴承改良参考额定寿命计算方法的知识点。重点将放在滚动轴承额定寿命的计算上,以及ISO/TS16281:2008(E)标准所涉及的内容。 首先,ISO国际标准...

    WinCE下冷启动程序自动安装装载

    ### WinCE下冷启动程序自动安装装载 在深入探讨如何实现Windows CE(简称WinCE)下的冷启动程序自动安装装载之前,我们先来了解一下WinCE系统的一些基本概念以及为何需要进行冷启动程序的自动安装。 #### Windows ...

    导线计算(自动装载数据vb程序).

    导线计算(自动装载数据VB程序) 本资源是一个基于VB程序的导线计算工具,包含了源代码和相关的图件。该工具能够进行导线计算,自动装载数据,提供了一个完整的解决方案。 知识点: 1. 导线计算:该工具可以进行...

    TCPIP高效编程:改善网络程序的44个技巧 PDF中文版带书签-目录

    3.3 技巧17:考虑用inetd来装载应用程序 111 3.3.1 TCP服务器 111 3.3.2 UDP服务器 114 3.3.3 小结 118 3.4 技巧18:考虑用tcpmux为服务器“分配”知名端口 118 3.5 技巧19:考虑使用两条TCP连接 126 3.5.1 单...

    程序集动态装载与卸载

    学习网上的相关介绍,写成的完整类,可以直接使用,用于动态装载并执行程序集中的方法 也可以使用插件管理域进行动态装载\执行方法\卸载程序域 但日常工作中还是习惯对所有项目引用一个公共的项目(主要是设计接口\...

    最优装载问题 c++

    最优装载问题,也被称为集装箱装载或货车装载问题,是一个经典的组合优化问题,广泛应用于物流、运输和资源分配等领域。在该问题中,我们需要在有限的空间内最大化装载物品的数量,同时确保不超出容器的容量限制。这...

    C++最优装载问题

    总的来说,C++最优装载问题的解决需要理解物品的价值和重量,结合编程技巧如动态规划或贪心策略,以及利用像Visual Studio这样的集成开发环境来组织和调试代码。此外,对于大型系统,还需要考虑如何有效地搜索最佳...

    轮船装载问题(回溯法与动态规划法的综合)

    2. **编程技巧**:在实现过程中,合理地利用数组和函数可以极大地简化代码结构,提高程序的可读性和可维护性。 3. **问题抽象**:将实际问题抽象成数学模型,并通过算法求解,是解决复杂问题的有效手段之一。 通过...

    S7-1500 PLC装载存储器已使用容量变红的解决方法示例.docx

    ### S7-1500 PLC装载存储器已使用容量变红的解决方法示例 #### 一、问题概述 在使用西门子S7-1500系列可编程逻辑控制器(PLC)的过程中,可能会遇到装载存储器已使用容量变红的情况,这通常意味着存储容量即将耗尽...

    动手实验 Oracle Hadoop装载程序

    Oracle Hadoop装载程序是一个用于将Hadoop上的数据文件装载到Oracle数据库中的工具,它允许用户通过简单配置和执行,实现大数据到传统关系型数据库的迁移和处理。Oracle Hadoop装载程序可以处理多种格式的数据文件,...

    计算机算法_最优装载

    大学本科计算机算法课程要求程序,C语言编写,最优装载

    如何将用户程序从装载存储区复制到主存储区中.doc

    这个过程涉及到从装载存储区将程序复制到主存储区,以供CPU运行。以下是关于这一过程的详细说明: 1. **装载存储区与主存储区**: - **装载存储区(Load Memory)**:这是程序的源代码或编译后的二进制文件存放的...

    精彩编程与编程技巧-避免装载多份应用程序...

    ### 避免装载多份应用程序的重要性和实现方法 在软件开发过程中,特别是桌面应用程序的开发中,确保程序只能运行一个实例是非常重要的。这不仅能提高应用程序的性能和稳定性,还能提升用户体验。本篇文章将深入探讨...

    装载优化说明 运输业(货物装载)

    它以提高物流主体作业“运送”、“保管”的装载效率,以削减物流成本为目的,通过最优化装载分析过程,在物流企业不发生实际货物物理转移的情况下,综合考虑货物形状、装载安全性、空间利用率等因素,利用计算机做...

    链接器和装载器

    链接器和装载器是计算机系统中的关键组件,它们在程序的生命周期中扮演着至关重要的角色。本文将深入探讨这两个概念,以及它们如何协同工作来构建和执行可执行程序。 首先,我们来理解“链接器”(Linker)。链接器...

    汇编自启动可装载运行其它小程序,操作系统

    总而言之,汇编自启动可装载运行其它小程序的操作系统实验,是一个涵盖汇编语言编程、操作系统原理等多个领域的综合性项目。通过这样的实验,学生不仅能够学习汇编语言的编程技巧,还能够深入理解操作系统的内部工作...

Global site tag (gtag.js) - Google Analytics