What?

  如何给变量命名

Why?

  1. 易读(你三个月前的代码=别人的代码),易记,恰如其分
  2. 整齐的命名具有美感,强迫症患者居家旅行杀人放火之必备

How?

以问题为导向

  好名字反映的是问题(what),并非解决方案(how)。名字不应体现计算细节

  • // good
    Object studentData;
    int sum;
    // bad
    Object inputData;
    int calcValue;

控制变量名长度

  • 合适的变量名长度为10~16个字符
  • 较长的名字适用于少用到的全局变量,较短的名字适用于局部变量、循环变量
  • 计算限定词total, sum, average, max, min, count, index等需要加到变量名最后
    int revenueTotal, expenseAverage, expenseTotal;
    int studentCount, studentIndex;

合理使用对仗词

  • begin/end
  • first/last
  • locked/unlocked
  • min/max
  • next/previous
  • old/new
  • opened/closed
  • visible/invisible
  • source/target
  • source/destination
  • up/down

循环变量

  • 循环内用简单的i, j, k, l,不要在循环外使用这些作为变量名,因为它们已经太深入人心了
  • 嵌套循环,需要明确变量名
  • 循环外用到的循环变量,需要需要明确变量名

状态变量、标志位

  • 避免使用flag、status这些不具备明确意义的名字
  • 使用paid、approved这些可以直接读懂的更好

临时变量

  • 别用temp、tmp,要使用有明确意义的

布尔变量

  • good:done、found、error、success、fileAvailable
  • bad:isDone、isFound,is是多余的
  • bad:done/undone、success/fail,可以用一个变量解决的问题不必再额外增加一个(!done、!success)

枚举类型

  • 要体现出自己是一个枚举组中的一员,如Color.Black、Color.White

    public Enum Color {
    Black,
    White
    }
    Color black = Color.Black;

常量

  • 大写字母,下划线分隔。除此之外不应在变量名中出现下划线

关于缩写

  • 去掉所有的非前置元音,如computer->cmptr、screen->scrn、integer->intgr
  • 去掉虚词and、or、the
  • 使用每个单词的第一个或前几个字母
  • 统一在每个单词的第一/第二/第三个字母处截断
  • 去除无用后缀,如ed、ing
  • 反复缩减直到长度控制在20字符
  • bad:b4、hilite
  • bad:myVar
  • 缩写要一致,一次使用终身使用

Bad Manners

  • 变量名中使用数字,如file1、file2
  • 拼错单词
  • 仅仅靠大小写来区分
  • 中英混杂

《Code Complete》ch.11 变量名的力量的更多相关文章

  1. <<代码大全>>阅读笔记之二 变量名的力量

    1.变量命名的注意事项 1)可理解性 变量要望文知义,看到这个变量不用看其他的代码就知道这个变量表示什么意思 好的变量命:currentDate, heartRate 糟糕的变量名:newButton ...

  2. Programming | 变量名的力量

    命名准则 变量名要完全,准确的描述变量所代表的事物,一般而言,对变量的描述就是最佳的变量名.避免x,temp,i等泛泛而谈的变量名. 比如对于矩阵的循环,matrix[row][col]就比m[i][ ...

  3. 《Code Complete》ch.16 控制循环

    WHAT? 反复执行的代码片段(你是第一天学编程吗) WHY? 知道如何使用及何时使用每一种循环是创建高质量软件的一个决定性因素 HOW? 检测位于循环开始/循环结尾 带退出的循环 进入循环 只从一个 ...

  4. 使用VS Code开发TypeScript--定义变量推荐使用let

    使用VS Code开发TypeScript--定义变量推荐使用let 目录 作用域规则 JavaScript的严格模式 let与var的区别 作用域规则 一直以来我们都是通过var关键字定义JavaS ...

  5. VS code 中的各种变量 ${file},${fileBasename}

    VS code 中的各种变量 ${file},${fileBasename} 2017年08月24日 11:14:07 bailsong 阅读数:7108    from: https://blog. ...

  6. code complete part1

    最近在看code complete,学习了一些东西,作为点滴,记录下来. 关于类: 类的接口抽象应该一致 类的接口要可编程,不要对类的使用者做过多的假设.不要出现类似于:A的输入量一定要大于多少小于多 ...

  7. 通过反射将变量值转为变量名本身ZZ

      这是.NET反射的一个有趣小例子:  通过反射将变量值转为变量名本身. 当然要先添加命名空间:using System.Reflection; 示例代码如下: class Program { st ...

  8. eclipse代码自动提示设置、如何配置eclipse的代码自动提示功能(同时解决自动补全变量名的问题)?

    对于编程人员来说,要记住大量的类名或类方法的名字,着实不是一件容易的事情.如果要IDE能够自动补全代码,那将为我们编程人员带来很大帮助. eclipse代码里面的代码提示功能默认是关闭的,只有输入“. ...

  9. Code Complete阅读笔记(一)

    代码大全也读了好几个月了,一开始读中文版,到现在慢慢尝试着读原版,确实感受到了"每天进步一点点"的魅力.遗憾的是没有从一开始就做阅读记录,总有不能尽兴和思路不清之感.确实,就像项目 ...

随机推荐

  1. Jenkins: 基础篇(环境配置)

    自动化领域比较有影响力的开源框架jenkins,确实比较强大,易用.很多公司将其用来做持续即成CI(continuous integration).为了拓展和强化自己的软件设计生态系统,也将很久前使用 ...

  2. Python基础教程【读书笔记】 - 2016/6/26

    希望通过博客园持续的更新,分享和记录Python基础知识到高级应用的点点滴滴! 第一波:第6章  抽象 [总览] 介绍函数.参数parameter.作用于scope概念,以及递归概念. [6.1] 函 ...

  3. Redis-sentinel监控

    Sentinel介绍 Redis的 Sentinel 系统用于管理多个Redis服务器, 该系统执行以下三个任务: 监控(Monitoring) 提醒(Notification) 自动故障迁移(Aut ...

  4. php定时执行脚本

    php定时执行脚本 ignore_user_abort(); // run script. in background set_time_limit(0); // run script. foreve ...

  5. java处理日期时间

    java.util.Calendar Calendar 类是一个抽象类,它为特定瞬间与一组诸如 YEAR.MONTH.DAY_OF_MONTH.HOUR 等 日历字段之间的转换提供了一些方法,并为操作 ...

  6. 开发高峰时的CPU使用率

  7. c# Base64编码和图片的互相转换代码

    将图片转化为Base64字符串的流程是:首先使用BinaryFormatter将图片文件序列化为二进制数据,然后使用Convert类的ToBase64String方法.将Base64字符串转换为图片的 ...

  8. 在ScrollView中嵌入GridView

    做android程序开发的都知道,不能在一个拥有Scrollbar的组件中嵌入另一个拥有Scrollbar的组件,因为这不科学,会混淆滑动事件,导致只显示一到两行数据.那么就换一种思路,首先让子控件的 ...

  9. Struts2返回JSON对象的方法总结

    如果是作为客户端的HTTP+JSON接口工程,没有JSP等view视图的情况下,使用Jersery框架开发绝对是第一选择.而在基于Spring3 MVC的架构下,对HTTP+JSON的返回类型也有很好 ...

  10. C#中调用Windows API的要点 .

    介绍 API(Application Programming Interface),我想大家不会陌生,它是我们Windows编程的常客,虽然基于.Net平台的C#有了强大的类库,但是,我们还是不能否认 ...