• Google C++编程风格指南


    前言


     

      从小就写字很挫,所以受够了被人鄙视的感觉,今天有个coder突然跟我说,你的代码怎么像小孩写的一样,顿时心情沮丧的极点。越来越发现一致的编程风格的重要性,于是把Google的C++编程风格指南看了一遍, 这里记录下于自己有益的rules。当规则有多个选择时,这里只记录个人习惯的用法, 并不代表它是唯一的用法。


    命名约定

    命名管理是最重要的一致性规则,因此我把它放在最前面。

    • 尽可能给出描述性名称。
    int num_errors; 
    int num_completed_connections;
    • 文件名全部小写,用下划线做连接符。
    my_useful_class.cc
    • C++文件以.cc 结尾,头文件以.h 结尾。(从.cpp切换到.cc)
    my_useful_class.cc
    my_useful_class.h
    • 类型命名每个单词以大写字母开头,不包含下划线。类、结构体、类型定义(typedef) 、枚举都使用相同约定。
    // classes and structs
    class UrlTable { ...
    class UrlTableTester { ...
    struct UrlTableProperties { ...
    
    // typedefs
    typedef hash_map<UrlTableProperties *, string> PropertiesMap;
    
    // enums
    enum UrlTableErrors { ...
    • 变量名一律小写,单词之间用下划线连接。类的成员变量以下划线结尾。
    my_exciting_local_variable
    my_exciting_member_variable_
    • 结构体的数据成员可以和普通变量一样,不用像类那样接下划线。
    struct UrlTableProperties {
        string name;
        int num_entries;
    }
    • 少用全局变量,要用的话用g作为其前缀(不喜欢用g_)。
    bool gInvalid = false;
    • 常量命名在名称前加k。
    const int kDaysInAWeek = 7;
    • 函数名的每个单词首字母大写,没有下划线。
    AddTableEntry()
    DeleteUrl()
    • 取值和设值函数要与存取的变量名匹配,使用小写单词及下划线。
    class MyClass {
    public:
        ...
        int num_entries() const { return num_entries_; }
        void set_num_entries(int num_entries) { num_entries_ = num_entries; }
    
    private:
        int num_entries_;
    };
    • 非常短小的内联函数也可以用小写字母命名。
    void swap(int &a, int &b);
    int max(int a, int b);
    bool cmp(Type t1, Type t2);
    • 名字空间用小写字母命名,并基于项目名称和目录结构:
    namespace google_awesome_project {
        ...
    }
    • 枚举值应该优先采用常量的命名方式。
    enum UrlTableErrors {
        kOK = 0,
        kErrorOutOfMemory,
        kErrorMalformedInput,
    };
    • 尽量避免使用宏,如果不得不用,请使用大写字母及下划线。
    #define ROUND(x) ...
    #define PI_ROUNDED 3.0
  • 相关阅读:
    T1-TensorFlow基础
    iOS之开发小技巧
    iOS之自定义控件
    plist文件的读取和xib加载cell
    iOS之tabBar随tableView的滑动而隐藏/显现
    iOS之initialize与load
    iOS之九宫格图片
    iOS之ToolBar定制
    iOS之新浪微博的OAuth授权
    Markdown的简单实用
  • 原文地址:https://www.cnblogs.com/akira90/p/3366867.html
Copyright © 2020-2023  润新知