Chinaunix首页 | 论坛 | 博客
  • 博客访问: 8050037
  • 博文数量: 594
  • 博客积分: 13065
  • 博客等级: 上将
  • 技术积分: 10324
  • 用 户 组: 普通用户
  • 注册时间: 2008-03-26 16:44
个人简介

推荐: blog.csdn.net/aquester https://github.com/eyjian https://www.cnblogs.com/aquester http://blog.chinaunix.net/uid/20682147.html

文章分类

全部博文(594)

分类: C/C++

2012-07-12 21:34:18

代码重构无处不在,重点滴做起。经常见到一些下面这样的代码:

1、不要拿bool和false直接比
if (false == IsXXX())
{
}

这是画蛇添足,费力不会讨好,直接了当即可:if (!IsXXX())


2、太多的if/else嵌套,导致过多缩进,造成眼花缭乱,阅读困难
if ()
{
    if ()
    {
        if ()
        {
            if ()
            {
                if ()
                {
                }
                else
                {
                }
            }
        }
    }
}

这个时候应当考虑提取成函数调用,以减少直接的if/else嵌套层次。同理,while/for也应当避免这种情况。


3、if代码块过长,else代码块仅两三行,典型的头得脚本,造成阅读困难
if (A == B)
{
    // 超过一屏的代码行
    // 代码行1
    // 代码行2
    // 代码行3
    // 代码行4
    // 代码行5
    // 代码行6
    // 代码行7
    // 代码行8
    // 代码行9
    // 代码行10
    // 代码行11
    // 代码行12
    // 代码行13
    // 代码行14
    // 代码行15
    // 代码行16
    // 代码行17
    // 代码行18
    // 代码行19
    // 代码行20
    // 代码行21
    // 代码行22
    // 代码行23
    // 代码行24
    // 代码行25
    // 代码行26
    // 代码行27
    // 代码行28
    // 代码行29
    // 代码行30
    // 代码行31
    // 代码行32
    // 代码行33
    // 代码行34
    // 代码行35
    // 代码行36
    // 代码行37
    // 代码行38
    // 代码行39
}
else
{
    // 两三行代码
    // 代码行1
    // 代码行2
    // 代码行3
}

由于if代码块超过了一屏,会大大增加阅读代码的困难,特别是要找到if对应的else时,不得不非常小心。建议遇到这类代码时,将if和else代码块对调,会值得阅读代码容易许多,如下所示:

if (A != B)
{
    // 两三行代码
    // 代码行1
    // 代码行2
    // 代码行3
}
else
{
    // 超过一屏的代码行
    // 代码行1
    // 代码行2
    // 代码行3
    // 代码行4
    // 代码行5
    // 代码行6
    // 代码行7
    // 代码行8
    // 代码行9
    // 代码行10
    // 代码行11
    // 代码行12
    // 代码行13
    // 代码行14
    // 代码行15
    // 代码行16
    // 代码行17
    // 代码行18
    // 代码行19
    // 代码行20
    // 代码行21
    // 代码行22
    // 代码行23
    // 代码行24
    // 代码行25
    // 代码行26
    // 代码行27
    // 代码行28
    // 代码行29
    // 代码行30
    // 代码行31
    // 代码行32
    // 代码行33
    // 代码行34
    // 代码行35
    // 代码行36
    // 代码行37
    // 代码行38
    // 代码行39
}

当然更佳的习惯,是不要有过长的代码块,应当考虑封装成函数。
阅读(3354) | 评论(9) | 转发(2) |
给主人留下些什么吧!~~

Aquester2012-07-27 16:58:33

GFree_Wind: 函数要尽可能的维持在50行左右。.....
函数行数确实最好不要超过50,19寸宽屏大概一屏显示30行左右,超过50行的函数就是大函数了,超过80就是超大函数了。

Aquester2012-07-16 22:17:40

Bean_lee: 10行太夸张了,大量的函数调用,压栈弹栈会伤性能。
反正超过150行的代码,都会引起我的反感。.....
确实,一个400行的函数就超大了

Bean_lee2012-07-16 18:09:35

fireaxe: 据某位高人说,函数最好不好超过10行.....
10行太夸张了,大量的函数调用,压栈弹栈会伤性能。
反正超过150行的代码,都会引起我的反感。

Aquester2012-07-16 14:29:24

fireaxe: 据某位高人说,函数最好不好超过10行.....
不超过10行,有点夸张了吧,那样反而有问题,会导致函数粒度过细,大量的小函数不但可能引入性能问题,而且一样会难看。分函数其实就是分层,目的是让更容易理解,而不是反着来,函数就象对一个段落的归纳总结,小学语文时经常干的事。

fireaxe2012-07-16 13:31:26

据某位高人说,函数最好不好超过10行