函数

短小

  • 20世纪80年代常说,函数不该长于一屏。
    那时候一屏只有20行,80列。
    现在能显示大概100行,150个字符,但是函数也不应该占满屏幕,20行封顶最佳。
  • 代码块和缩进
    if语句、else语句、while语句等,其中代码块应该只有一行。该行大抵应该是一个函数调用语句。
    这也意味着函数不应该大到足以容纳嵌套结构。所以,函数的缩进层级不该多于一层或两层。

只做一件事

  • 如果函数只是做了该函数名下同一抽象层上的步骤,则函数还是只做了一件事。
  • 要判断函数是否不止做了一件事,还有一个方法,就是看是否能再拆出一个函数,该函数不仅只是单纯地重新诠释其实现。
  • 只做一件事的函数无法被合理的切分为多个区段。

每个函数一个抽象层级

函数中混杂不同的抽象层级,往往让人迷惑。一旦细节和基础概念混杂,细节就会在函数中纠结起来。
要让每个函数后面都跟着位于下一抽象层级的函数。

switch语句

问题:

  1. 太长,当出现新的条件时,还会变得更长
  2. 不止做了一件事
  3. 违反了单一权责原则
  4. 违反了开闭原则,每当添加新类型时,就必须修改。
    解决方案:
    将switch语句埋到抽象工厂底下。

使用描述性的名称

  • 函数越短小、功能越集中,就越便于取个好名字。
  • 别害怕长名称。
  • 别害怕花时间取名字。
  • 选择描述性的名称能理清关于模块的设计思路,并帮助改进之。追索好名称,往往导致对代码的改善重构。
  • 命名方式要保持一致。

函数参数

最理想的参数数量是零,其次是一,再次是二,应尽量避免三参数函数。

  • 参数不易对付。
    它带有太多概念性。以StringBuffer为例,作为参数传递时,读者每次看到都得翻译一遍。参数和函数名处于不同的抽象层级。
  • 参数让测试变的困难。
    如果参数多余两个,测试覆盖所有可能的组合让人生畏。
  • 输出参数比输入参数还要难以理解
    信息通过参数输入函数,通过返回值从函数输出。尽量不要让信息通过参数输出。
一元函数的普遍形式

向函数传入单个参数有两种极普遍的的理由。
你也许会问关于那个参数的问题。也可能是操作参数,将其转换为其他什么东西,再输出之。
还有一种不普遍但极有用的单参数函数形式,事件。这种形式,有输入参数无输出参数。小心使用这种形式。
尽量避免编写不遵循这些形式的一元函数。例如,void includeSetupPageInto(StringBuffer pageText)。对于转换,应该使用返回值,而不应该使用输出参数。StringBuffer transform(StringBuffer in)要比void transform(StringBuffer out)强,它遵循了转换的形式。

标识参数

向函数传入布尔值是丑陋的做法。它直接告诉我们这个函数不止做一件事,传入true将会这样做,传入false则会那样做。

二元函数

尽管有些时候两个参数刚好。比如Point p = new Point(0,0),笛卡尔点天生就有两个参数。但是这是因为这两个参数是单个值的有序组成部分。
其他的就不好了,即使是如assertEquals(expected,actual),这样的二元函数也有问题。你会经常搞错这两个参数的位置。这两个参数没用自然的顺序。
尽量利用一些机制把二元函数转换成一元函数。例如,writeFiled(outputStream,name),可以把writeField方法写成outputStream的成员函数,从而能这样用:outputStream.writeField(name)。或者,也可以把outputStream写成当前类的成员变量,从而无需再传递它。还可以分离出类似FieldWriter的新类,在其构造器中采用outputSteam,并且包含一个write方法。

三元函数

排序、琢磨、忽略的问题都会加倍体现。
当然也有一些函数写成三参数还是可以不错的。

参数对象

如果函数看来需要两个、三个、或三个以上参数,就说明其中一些参数应该封装为类类。当一组参数被共同传递,往往就是该有自己名称的某个概念的一部分。

参数列表

有时,我们需要向函数传入数量可变的参数。例如,String.format方法。
但是这个方法实则是二元函数。

动词与关键字

给函数取个好名字,能很好的解释函数的意图,以及参数的顺序和意图。把参数的名称编码成函数名。例如write(name)和writeField(name),它告诉我们name是一个field,assertEqual()改成assertExpectedEqualsActual(expected,actual)会好些。这大大减轻了记忆参数顺序的负担。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,242评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,769评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,484评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,133评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,007评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,080评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,496评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,190评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,464评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,549评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,330评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,205评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,567评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,889评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,160评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,475评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,650评论 2 335

推荐阅读更多精彩内容