`
zxq198181
  • 浏览: 13836 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

改良程序需要的11个技巧(转csdn)

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


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


   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?在你的项目之外做一些小例子,当完全弄懂了后,丢掉例子,应用到你的产品里
分享到:
评论

相关推荐

    csdn文章转换为markdown格式

    标题中的“csdn文章转换为markdown格式”指的是一个自编的小程序,它可以便捷地抓取csdn网站上的文章内容,并将其格式化为Markdown语言。对于经常在csdn上阅读和学习的用户来说,这个工具能帮助他们更方便地整理和...

    CSDN最全面的微信小程序源码和模板

    从事微信小程序开发也有差不多半年的时间了,本人深知对于从来都没有接触过微信小程序开发的人刚开始是多么的迷茫,无助。其实我刚开始也是这样,然而进过一段时间的开发,学习,我知道了其实网上有很多人进行分享过...

    微信小程序通过BLE低功耗蓝牙向USB HID键盘设备输出汉字(内含GBK编码转汉字)_小程序 gbk-CSDN博客.mhtml

    微信小程序通过BLE低功耗蓝牙向USB HID键盘设备输出汉字(内含GBK编码转汉字)_小程序 gbk-CSDN博客.mhtml

    CSDN积分获取方法.docx

    CSDN积分获取方法

    CSDN Share:大会PPT合集下载,纯干货!

    CSDN Share 是一款出色的Android阅读工具,阅读由 CSDN社区用户分享的技术文档。 通过CSDN Share可以在线阅读或离线下载CSDN 举办的各类技术活动的精彩讲义,以及来自CSDN下载社区由用户分享的技术文档。 马上下载...

    CSDN app(完)

    【CSDN app】是一个基于Android平台的应用程序,主要用于浏览和互动CSDN(China Software Developer Network)上的博客和技术文章。这个应用集成了多种功能,包括但不限于阅读、搜索、评论和分享,旨在方便开发者们...

    OpenFaaS实战之七:java11模板解析(csdn)————程序.pdf

    OpenFaaS实战之七:java11模板解析(csdn)————程序

    usb转485驱动程序,win10-64,HXSP-2108F

    标签"HXSP-2108F"代表了适配器的具体型号,通常每个设备都有其独特的硬件ID,驱动程序需要匹配这些ID才能正常工作。这个标签可能用于区分不同制造商或版本的USB转485适配器。 压缩包内的"232转485(HXSP-2108F)"可能...

    CSDN博客提取器修正版

    本程序用java编写,运行的时候需要JDK1.5或以上环境,无需安装。程序通过分析CSDN博客源码来生成一些必要的数据,可能在以后使用当中出现爬取不了的情况,可能是CSDN的源码结构修改了。程序只是用于学习之用,严禁...

    PCB抄板技巧

    PCB抄板技巧,转换后的pcb文件可以在protel for dos 、protel for windows软件中调入,我们以此为背景在另一层重画此图,完成后,将背景图整层删除,存盘即可。

    CSDN博客便捷式帮助小程序

    只需要运行程序,输入我们的账号,就可以以类似Linux命令的方式,执行一些我们需要的命令。 1、查看CSDN个人信息; 2、展示账号下CSDN博客信息; 3、根据关键字查找账号下的博客信息; 4、查看博客数目; 5、其它...

    win11安装ie11浏览器

    2. **下载并安装“IE11恢复程序”**:由于Win11默认不包含IE11,你需要找到一个可靠的来源,如微软官方的“企业版Windows 10下载工具”,来下载包含IE11的更新文件。通常,这些更新文件会以`.msu`格式提供。下载后,...

    抓取CSDN博客文章的简单爬虫python源码

    在这个主题中,我们将探讨如何使用Python编写一个简单的爬虫程序来抓取CSDN博客的文章内容。CSDN(Chinese Software Developer Network)是中国的一个大型程序员社区,其中包含大量的技术博客,是获取编程知识的重要...

    微信小程序模板(几十个)

    "微信小程序模板(几十个)"这个资源集合很可能包含了多种类型和风格的小程序模板,例如电商、资讯、社交、娱乐等不同场景的应用模版。 这些模板可能包括了完整的页面结构、样式设计、交互逻辑以及部分业务逻辑,...

    近百个微信小程序模板(含源码)

    本资源包含近百个微信小程序的模板,每个模板都包含了完整的源码,这对于开发者来说是一份非常宝贵的参考资料,无论是初学者还是经验丰富的开发者,都能从中受益。 一、小程序模板的价值 1. 学习参考:这些模板覆盖...

    Android小巫CSDN博客客户端源码

    【Android小巫CSDN博客客户端源码】是一款基于Android平台的应用程序,旨在为用户提供一个方便的途径来阅读和浏览CSDN博客上的文章。这个源码是开发者小巫分享的,供其他开发者学习和参考,以提升Android开发技能。 ...

    CSDN博客下载器v2.2

    好消息:CSDN博客下载器v2.0版本增加导出PDF文件功能,方便查看图片与文章。 在无网络环境,也可以看自己的一些文章。当然如果您发现CSDN博客的一些文章值得收藏,你也可以使用本软件轻松的下载到您的电脑。 该版本...

    嵌入式,PL2303-win11驱动程序

    然而,根据标题和描述,存在一个问题,即PL2303的驱动程序可能不兼容最新的Windows 11操作系统。这意味着用户在尝试在Win11系统上使用PL2303设备时可能会遇到问题,如设备无法识别或功能受限。 为了解决这个问题,...

Global site tag (gtag.js) - Google Analytics