zoukankan      html  css  js  c++  java
  • Linux学习笔记:内核代码编码风格

    # 缩进
    使用8字符宽的缩进,使缩进更清晰。
    如果缩进超过3级,要考虑修改函数,可能过于复杂。
    case和switch对齐。

    # 断开过长的行、字符串

    # 使用括号
    除了函数,其他情况下 { 不单独占一行。

    # 命名
    不使用大小写混排的风格。
    不包含类型。
    全局变量命名要有描述性。
    局部变量命名要简短。

    # Typedef
    应该避免使用,会影响代码的可读性。

    # Function
    函数的长度与复杂度、缩进层级成正比。函数不应过长,不应由太深的缩进层级。

    局部变量的个数不能过多,小于5~10个。

    # Goto在特殊情况下可以使用

    # 注释
    清晰的代码不需要过多的注释。
    注释要说明what,而不是how。不要试图解释代码是如何工作的。
    在函数头前注释,说明what,函数体内不要有过多的注释。

    # 数据结构
    对于多个线程共享的数据,使用引用计数、Locking保护。

    引用计数:是内存管理技术。避免访问已经销毁的数据。
    Locking:保持数据的完整性。

    # Macro
    用大写字母命名。
    表达式必须用括号。
    不能包含控制流,如return。
    不能引用局部变量。
    定义多行语句时,包含在do-while语句块中。

    # 内存分配
    格式:p = kmalloc(sizeof(*p));
    这里推荐的方式和自己平时使用的不太一样:1) sizeof中没有使用类型,这样避免了不一致的可能性。2)返回指针不需要进行显式类型转换,C语言会完成从void* 到其它类型的转换。

    # inline
    避免使用inline,除非:函数小于3行,函数参数时编译时常量。
    过多使用inline会导致程序规模增大,增加了读硬盘的次数,执行效率反而降低。

    # 函数返回值的处理
    有两种返回值处理风格:
    1) error-code
    0~success, others-错误

    2) boolean
    0-false, 1-true

    使用规则:函数名称是动作、或命令,用风格1;函数名是判定,用风格2。



    # 缩进
    使用8字符宽的缩进,使缩进更清晰。
    如果缩进超过3级,要考虑修改函数,可能过于复杂。
    case和switch对齐。

    # 断开过长的行、字符串

    # 使用括号
    除了函数,其他情况下 { 不单独占一行。

    # 命名
    不使用大小写混排的风格。
    不包含类型。
    全局变量命名要有描述性。
    局部变量命名要简短。

    # Typedef
    应该避免使用,会影响代码的可读性。

    # Function
    函数的长度与复杂度、缩进层级成正比。函数不应过长,不应由太深的缩进层级。

    局部变量的个数不能过多,小于5~10个。

    # Goto在特殊情况下可以使用

    # 注释
    清晰的代码不需要过多的注释。
    注释要说明what,而不是how。不要试图解释代码是如何工作的。
    在函数头前注释,说明what,函数体内不要有过多的注释。

    # 数据结构
    对于多个线程共享的数据,使用引用计数、Locking保护。

    引用计数:是内存管理技术。避免访问已经销毁的数据。
    Locking:保持数据的完整性。

    # Macro
    用大写字母命名。
    表达式必须用括号。
    不能包含控制流,如return。
    不能引用局部变量。
    定义多行语句时,包含在do-while语句块中。

    # 内存分配
    格式:p = kmalloc(sizeof(*p));
    这里推荐的方式和自己平时使用的不太一样:1) sizeof中没有使用类型,这样避免了不一致的可能性。2)返回指针不需要进行显式类型转换,C语言会完成从void* 到其它类型的转换。

    # inline
    避免使用inline,除非:函数小于3行,函数参数时编译时常量。
    过多使用inline会导致程序规模增大,增加了读硬盘的次数,执行效率反而降低。

    # 函数返回值的处理
    有两种返回值处理风格:
    1) error-code
    0~success, others-错误

    2) boolean
    0-false, 1-true

    使用规则:函数名称是动作、或命令,用风格1;函数名是判定,用风格2。



  • 相关阅读:
    JSON 序列化类 南京酷得软件
    哈哈哈哈哈哈 找回记忆
    Presto
    (转)在Total Commander下使用SVN
    在ubuntu12.04,64位中安装lnmp一键包mysql的问题
    阿里云服务器上搭建php环境+redis
    在ubuntu12.04,64位中安装nginx+php+redis+mysql
    Redis篇:单线程I/O模型
    工具篇:apachehttpClient 和 jdk11HttpClient的使用
    技能篇:关于缓存数据的一致性探讨
  • 原文地址:https://www.cnblogs.com/weichsel/p/1845289.html
Copyright © 2011-2022 走看看