码迷,mamicode.com
首页 > 其他好文 > 详细

顺序语句

时间:2014-10-11 10:37:35      阅读:190      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   使用   ar   java   for   strong   

顺序语句是程序语言控制结构中最基础,最简单和最容易理解的一种,它确定了为完成某个功能先做什么,后做什么。分为有依赖关系的顺序语句无依赖关系的顺序语句

 

一、有依赖关系的顺序语句

 

示例1

var myForm = document.forms[‘myForm‘]
var uname = myForm.uname.value
var pwd = myForm.pwd.value
login(uname, pwd)

这是Web前端开发过程中的一个登录场景,从form表单中获取用户名和密码,调用登录函数完成登录。很明显这几行代码之间有依赖性,第二三句依赖于第一句,第四句依赖于第二三句。它们的依赖关系从代码中发现,有依赖关系的是不能随意调换语句顺序。

 

示例2

order.computeAdult() 
order.computeChild()
order.computeCoupon()
var total = order.computeTotal()

这几句的依赖关系就没有那么明显了,你很难了解它内部的逻辑,即每一个语句被调用后它做了什么,有没有修改公用变量数据,对后续语句有没有影响。这实际是一个旅游订单结算业务,computeAdult计算成人的价格(成人价格*成人数量),computeChild计算儿童的价格(儿童价格*儿童数量),computeCoupon计算优惠券的价格(优惠券面值*数量),computeTotal则等于 "成人+儿童-优惠券"。

 

对于有依赖关系的顺序语句,应该通过以下方式增强其可读性

1. 使子程序名凸显依赖关系

比如示例2的计算支付总价的,都以computeXXX格式,至少这样能猜到是在做同一件事,需要拆为几个步骤。

 

2. 利用子程序的参数凸显依赖关系

比如示例2,可以每次都把价格参数传入

order.computeAdult(price) 
order.computeChild(price)
order.computeCoupon(price)

由于所有的子程序都使用了price,你会从中得到暗示,这几个子函数可能操作了相同的数据变量

 

当然还有一种更好方式,把子程序操作的结果变成下一个子程序的输入,这样依赖关系就很显眼了

price = order.computeAdult(price) 
price = order.computeChild(price)
price = order.computeCoupon(price)

 

3. 用注释对复杂的依赖关系进行说明

如果还担心某些依赖关系不够清晰,那就用注释说明它以弥补代码的不足。

 

二、无依赖关系的顺序语句

无依赖关系的顺序语句即是一条语句并不依赖上一条语句,它们只是各自完成不同的功能,相互之间没有交集。

 

或许只有的语句可以随意写,比如

var $nav = $(‘#nav‘)
var $toolbar = $(‘#toolbar‘)
var $content = $(‘#content‘)

$toolbar.width(900)
$nav.heiht(300)
$content.css(‘color‘, ‘gray‘)

$toolbar.show()
$content.show()
$nav.show()

这实际在操作三个dom元素,改变后显示出来。作为一个普遍性原则,要让程序自上而下阅读,而不是目光被牵着跳来跳去。改成以下就清晰了许多

var $nav = $(‘#nav‘)
$nav.heiht(300)
$nav.show()

var $toolbar = $(‘#toolbar‘)
$toolbar.width(900)
$toolbar.show()

var $content = $(‘#content‘)
$content.css(‘color‘, ‘gray‘)
$content.show()

这段代码把每一个对象的引用都放在一起,把它们“局部化”。

 

对于无依赖关系的顺序语句,应该把相关的语句组织在一起。因为它们处理的是相同的数据,执行类似的任务。而一旦把相关的语句组织在一起,可能会发现它们之间有很强的联系,这时你可能会想把这些语句提取到一个子程序里。一个个相互独立的子程序慢慢把功能实现了,代码也清晰了。

 

顺序语句

标签:style   blog   http   color   使用   ar   java   for   strong   

原文地址:http://www.cnblogs.com/snandy/p/4018218.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!