zoukankan      html  css  js  c++  java
  • 代码规范

    代码规范

    • 缩进

      1. 程序块要采用缩进风格编写,缩进的空格数为 4 个。

      2. 缩进或者对齐只能使用空格键,不可使用 TAB 键。

        使用 TAB 键需要设置 TAB 键的空格数目是 4 格。

    • 变量命名

      1. 代码中的命名均不能以下划线或美元符号开始,也不能以下划线或美元符号结束。
        反例: _name / __name / $Object / name_ / name$ / Object$
        
      2. 代码中的命名严禁使用拼音与英文混合的方式,更不允许直接使用中文的方式。

        说明:正确的英文拼写和语法可以让阅读者易于理解,避免歧义。
        注意,即使纯拼音命名方式也要避免采用。

        反例: DaZhePromotion [打折] / getPingfenByName()  [评分] / int某变量 = 3
        正例: alibaba / taobao / youku / hangzhou等国际通用的名称,可视同英文。
        
    • 每行最多字符数

      1. 语句(>80 字符)要分成多行书写。
    • 函数最大行数

      1. 函数最大行数不超过100行
    • 函数、类命名

      1. 类名使用UpperCamelCase风格,必须遵从驼峰形式,但以下情形例外:(领域模型的相关命名)DO / BO / DTO / VO等。
        正例:MarcoPolo / UserDO / XmlService / TcpUdpDeal /   TaPromotion
        反例:macroPolo / UserDo / XMLService / TCPUDPDeal /   TAPromotion
        
      2. 方法名、参数名、成员变量、局部变量都统一使用lowerCamelCase风格,必须遵从驼峰形式。
         正例: localValue / getHttpMessage() /  inputUserId
        
      3. 抽象类命名使用Abstract或Base开头;异常类命名使用Exception结尾;测试类命名以它要测试的类的名称开始,以Test结尾。
    • 常量

      1. 常量命名全部大写,单词间用下划线隔开,力求语义表达完整清楚,不要嫌名字长。
        正例: MAX_STOCK_COUNT
        反例: MAX_COUNT
        
    • 空行规则

      1. 函数之间应该用空行分开。
      2. 变量声明应尽可能靠近第一次使用处,避免一次性声明一组没有马上使用的变量。
      3. 用空行将代码按照逻辑片断划分。
      4. 每个类声明之后应该加入空格同其他代码分开。
    • 注释规则

      1. 源文件头部应进行注释,列出:生成日期、作者、模块目的/功能等。
      2. 函数头部应进行注释,列出:函数的目的/功能、输入参数、输出参数、返回 值等。
      3. 注释应该和代码同时更新,不再有用的注释要删除。
    • 操作符前后空格

      1. 关键字之后要留空格。象 const、virtual、inline、case 等关键字之后至少要留一个空格, 否则无法辨析关键字。象 if、for、while 等关键字之后应留一个空格再跟左括号‘( ’, 以突出关键字。
      2. 函数名之后不要留空格, 紧跟左括号’(’ , 以与关键字区别。
      3. '('向后紧跟,')'、','、';'向前紧跟,紧跟处不留空格。
      4. ','之后要留空格,如Function(x, y, z)。如果';'不是一行的结束符号,其后要留空格,如for (initialization; condition; update)。
      5. 值操作符、比较操作符、算术操作符、逻辑操作符、位域操作符,如“ =”、“ +=”、“ >=”、“ <=”、“ +”、“ *”、“ %”、“ &&”、“ ||”、“ <<” 、“ ^” 等二元操作符 的前后应当加空格。
      6. 一元操作符如“ !”、“ ~”、“ ++”、“ --”、“ &”( 地址运算符) 等前后不加 空格。
      7. 象“[ ]”、“ .”、“ ->” 这类操作符前后不加空格。
    • 其他规则

      1. 中括号是数组类型的一部分,数组定义如下:String[] args;
        反例:请勿使用String  args[]的方式来定义。
        
      2. POJO类中布尔类型的变量,都不要加is,否则部分框架解析会引起序列化错误。
        反例:定义为基本数据类型boolean isSuccess;的属性,
        它的方法也是isSuccess(),RPC框架在反向解析的时候,“以为”对应的属性名称是success,导致属性获取不到,进而抛出异
        常。
        
      3. 包名统一使用小写,点分隔符之间有且仅有一个自然语义的英语单词。包名统一使用单数形式,但是类名如果有复数含义,类名可以使用复数形式。
        正例:应用工具类包名为com.alibaba.open.util、类名为MessageUtils(此规则参考spring的框架结构)
        
      4. 杜绝完全不规范的缩写,避免望文不知义。
        反例: AbstractClass“缩写”命名成AbsClass;condition“缩写”命名成 condi,此类随意缩写严重降低了代码的可阅读性。
        

    参考

    [1] 《码出高效_阿里巴巴Java开发手册》
    [2] 《腾讯c++代码规范》

  • 相关阅读:
    第三部分:填写志愿的思路
    第二部分:志愿录取标准
    2017年浙江省高考志愿、录取闪电入门系列 目录
    七、程序包
    五、过程式编程和调试技巧
    四、表达式的计算
    三、函数与递归
    二、表操作
    一、MMA概述
    Java面向对象
  • 原文地址:https://www.cnblogs.com/021700613h/p/12955878.html
Copyright © 2011-2022 走看看