RM新时代网站-首页

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線(xiàn)課程
  • 觀看技術(shù)視頻
  • 寫(xiě)文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

C語(yǔ)言代碼規(guī)范

科技綠洲 ? 來(lái)源:工程師進(jìn)階筆記 ? 作者:工程師進(jìn)階筆記 ? 2023-06-22 10:38 ? 次閱讀

1. 前言

本文是AliOS Things提供的一套C語(yǔ)言代碼規(guī)范,適用的對(duì)象為符合C99標(biāo)準(zhǔn)的C語(yǔ)言工程。

2. 命名

本節(jié)內(nèi)容均為建議,不作強(qiáng)制要求。

2.1. 總則

各種命名均使用英文單詞及其縮寫(xiě),非特殊情況不能使用漢語(yǔ)拼音或其他語(yǔ)言。

2.2. 文件命名

文件名全部使用小寫(xiě)字母,用_連接。源文件使用.c后綴。頭文件使用.h后綴。

2.3. 類(lèi)型命名

2.3.1. 簡(jiǎn)單類(lèi)型命名

使用typedef自定義的簡(jiǎn)單類(lèi)型命名全部使用小寫(xiě)字母,用_連接,以_t結(jié)尾。例如:

typedef int32_t aos_status_t;

2.3.2. 結(jié)構(gòu)體和聯(lián)合體命名

結(jié)構(gòu)體和聯(lián)合體類(lèi)型命名全部使用小寫(xiě)字母,用_連接。建議使用typedef定義一個(gè)整體的名字,以_t結(jié)尾。例如:

typedef struct aos_list_node {
    struct aos_list_node *prev;
    struct aos_list_node *next;
} aos_list_node_t;

static aos_list_node_t list_node;

2.3.3. 枚舉命名

枚舉類(lèi)型命名全部使用小寫(xiě)字母,用_連接。建議使用typedef定義一個(gè)整體的名字,以_t結(jié)尾。枚舉值命名全部使用大寫(xiě)字母,用_連接,包含表示類(lèi)型的前綴。例如:

typedef enum aos_socket_stage {
    AOS_SOCK_STG_DISCONNECTED,
    AOS_SOCK_STG_CONNECTED,
} aos_socket_stage_t;

static aos_socket_stage_t sock_stage = AOS_SOCK_STG_DISCONNECTED;

2.4. 變量命名

變量命名全部使用小寫(xiě)字母,用_連接。數(shù)組名稱(chēng)盡量使用復(fù)數(shù)名詞。例如:

cfg_file_t cfg_files[NUM_CFG_FILES];

表示數(shù)目的變量名稱(chēng)使用num(number的縮寫(xiě))加復(fù)數(shù)名詞。例如:

unsigned int num_files;

表示序號(hào)的變量名稱(chēng)使用單數(shù)名詞加num或index或idx(index的縮寫(xiě))。例如:

unsigned int file_num;
unsigned int file_index;

2.5. 函數(shù)命名

函數(shù)命名全部使用小寫(xiě)字母,用_連接。

2.6. 宏命名

一般的宏命名全部使用大寫(xiě)字母,用_連接。例如:

#define AOS_STRING_MAX_LEN 127

模擬函數(shù)使用方式的宏的命名規(guī)則與函數(shù)相同。例如:

#define aos_dev_set_id(dev, x) \\
    do { \\
        (dev)- >id = (x); \\
    } while (0)

2.7. 前綴

為防止命名空間污染,公用組件中的非static函數(shù)、非static全局變量、全局類(lèi)型、全局宏的命名應(yīng)帶有前綴。例如(假設(shè)前綴為aos):

void aos_cfg_file_close(int fd);
extern char **aos_process_argv;
typedef struct aos_list_node aos_list_node_t;
#define AOS_STRING_MAX_LEN 127

3. 格式

3.1. 文本格式

源文件、頭文件、Makefile等文本文件一律采用UTF-8 without BOM編碼,采用Unix風(fēng)格換行格式。文本文件末尾應(yīng)有且只有一個(gè)換行符,即末尾應(yīng)有且只有一個(gè)空行。

3.2. 行長(zhǎng)度

每行字符數(shù)原則上不超過(guò)120。包含長(zhǎng)路徑的#include語(yǔ)句、頭文件#define保護(hù)可以無(wú)視此規(guī)則。

3.2.1. 表達(dá)式換行

較長(zhǎng)的表達(dá)式可在運(yùn)算符處換行,換行處的運(yùn)算符屬于舊行,新行對(duì)齊到舊行中的相同邏輯層級(jí)。例如:

void foo(void)
{
    if ((aos_list_next(list_node) != &list_head && !priv) ||
        !(strcmp(symbol, default_symbol) && blahblahblahblahblahblah() &&
          meomeomeomeomeomeomeomeomeomeomeomeomeomeomeomeo(NULL))) {
        /* ... */
    }
}

3.2.2. 函數(shù)換行

較長(zhǎng)的函數(shù)定義、聲明可在返回值類(lèi)型和函數(shù)名稱(chēng)之間換行。若返回值為指針類(lèi)型,*屬于新行。例如:

static unsigned long
blahblahblahblahblahblahblahblahblahblahblahblahblahblahblahblahblahblah(void);
static const manager_priv_t
*blahblahblahblahblahblahblahblahblahblahblahblahblahblahblahblah(int index);

較長(zhǎng)的函數(shù)定義、聲明、調(diào)用可在參數(shù)列表中間換行,參數(shù)列表中間換行后新行應(yīng)縮進(jìn)至舊行第一個(gè)參數(shù)處。例如:

void blahblahblahblahblahblahblahblahblah(manager_priv_t *priv, int index,
                                          const char *proc_name);

void foo(void)
{
    blahblahblahblahblahblahblahblahblahblah(get_manager_priv(manager), 0,
                                             "meomeomeomeomeomeomeomeo");
}

3.2.3. 字符串換行

較長(zhǎng)的字符串可在空格處換行,一般情況下?lián)Q行處的空格屬于舊行。例如:

void foo(void)
{
    printf("The GNU operating system consists of GNU packages "
           "(programs specifically released by the GNU Project) "
           "as well as free software released by third parties.\\n");
}

3.3. 縮進(jìn)

使用空格縮進(jìn),每次4個(gè)空格。全文不應(yīng)出現(xiàn)制表符(tab)。例如:

void foo(unsigned int nbr_processes)
{
    unsigned int i;

    while (i < nbr_processes) {
        const char *name;
        /* ... */
    }
}

宏定義、行尾注釋、結(jié)構(gòu)體、聯(lián)合體、枚舉等內(nèi)部可縮進(jìn)實(shí)現(xiàn)多行對(duì)齊,但不作強(qiáng)制要求。若有縮進(jìn),應(yīng)對(duì)齊到4的整數(shù)倍。例如:

/* 此處數(shù)字0縮進(jìn)32個(gè)字符,即位于第33列。 */
#define STAGE_UPDATE_CONTINUE   0
#define STAGE_UPDATE_COMPLETE   1

/* 合法 */
#define EVENT_RX_FULL (1U < < 0)
#define EVENT_TX_EMPTY (1U < < 1)

typdef enum socket_stage {
    /* 此處等號(hào)縮進(jìn)32個(gè)字符,即位于第33列。 */
    SOCK_STG_DISCONNECTED       = 0,
    SOCK_STG_CONNECTED          = 1,
} socket_stage_t;

/* 此處反斜杠縮進(jìn)40個(gè)字符,即位于第41列。 */
#define aos_dev_set_flags(dev, x)       \\
    do {                                \\
        (dev)- >flags = (x);             \\
    } while (0)

/* 合法 */
#define aos_dev_set_ops(dev, x) \\
    do { \\
        (dev)- >ops = (x); \\
    } while (0)

/* 此處注釋縮進(jìn)24個(gè)字符,即位于第25列。 */
foo(NULL);              /* abc */
blahblahblahblahblah(); /* xyz */

/* 合法 */
foofoofoo(); /* abc */
foofoo(); /* xyz */

分行定義的宏,第二行起應(yīng)縮進(jìn)一次。例如:

#define aos_dev_set_id(dev, x) \\
    do { \\
        (dev)- >id = (x); \\
    } while (0)

switch塊中的case語(yǔ)句和default語(yǔ)句與switch語(yǔ)句縮進(jìn)層級(jí)相同。例如:

switch (stage) {
case SOCK_STG_DISCONNECTED:
    foo();
    break;
case SOCK_STG_CONNECTED:
    sock- >connected = 1;
    break;
default:
    break;
}

3.4. 花括號(hào)

函數(shù)體的左花括號(hào)另起一行;其他情況下左花括號(hào)不另起一行。一般情況下左花括號(hào)后續(xù)內(nèi)容另起一行;宏定義中、數(shù)組、結(jié)構(gòu)體、聯(lián)合體初始化時(shí)若花括號(hào)中內(nèi)容較短則左花括號(hào)后續(xù)內(nèi)容可以不另起一行。一般情況下右花括號(hào)另起一行;宏定義中、數(shù)組、結(jié)構(gòu)體、聯(lián)合體初始化時(shí)若花括號(hào)中內(nèi)容較短則右花括號(hào)可以不另起一行。右花括號(hào)與后續(xù)內(nèi)容組合成一行。例如:

typedef struct manager_priv {
    int index;
    void *data;
} manager_priv_t;

#define set_manager_index(x, idx) do { (x)- >priv- >index = (idx); } while (0)

#ifdef __cplusplus
extern "C" {
#endif

void foo(void)
{
    int i = 0;

    /* ... */

    if (i == 0) {
        /* ... */
    } else {
        /* ... */
    }
}

manager_priv_t priv = { 0, NULL, };

#ifdef __cplusplus
}
#endif

3.5. 空格

行尾不應(yīng)有空格。三元操作符和二元操作符(獲取成員的.->操作符除外)前后留有空格。例如:

x = a ? b : c;
v = w * x + y / z;
len = x.length;
priv = proc- >priv;

一元操作符與參數(shù)之間不留空格。例如:

x = *p;
p = &x;
i++;
j = --i;

逗號(hào)右側(cè)若有內(nèi)容,逗號(hào)與右側(cè)內(nèi)容之間應(yīng)有空格。例如:

void foo(int x, int y);

分號(hào)右側(cè)若有內(nèi)容(右圓括號(hào)或另外一個(gè)分號(hào)除外),分號(hào)與右側(cè)內(nèi)容之間應(yīng)有空格。例如:

for (i = 0; i < strlen(str);) {
    for (;;) {
        /* ... */
    }
}

圓括號(hào)內(nèi)部?jī)?nèi)容與圓括號(hào)之間不留空格。例如:

len = strlen(name);

for (i = 0; i < count; i++) {
    /* ... */
}

圓括號(hào)與左側(cè)關(guān)鍵字之間應(yīng)有空格。例如:

while (1) {
    /* ... */
}

if (i == 0) {
    /* ... */
}

圓括號(hào)與左側(cè)函數(shù)名之間不留空格。例如:

int load_file(const char *name)
{
    foo(0);
    /* ... */
}

類(lèi)型轉(zhuǎn)換中的圓括號(hào)與右側(cè)內(nèi)容之間不留空格。例如:

manager_priv_t *priv = (manager_priv_t *)p;

方括號(hào)與左側(cè)內(nèi)容、內(nèi)部?jī)?nèi)容之間不留空格。例如:

c = name[i];

左花括號(hào)左側(cè)或右側(cè)若有內(nèi)容,左右內(nèi)容與左花括號(hào)之間應(yīng)有空格。右花括號(hào)左側(cè)若有內(nèi)容,左側(cè)內(nèi)容與右花括號(hào)之間應(yīng)有空格;右花括號(hào)右側(cè)若有內(nèi)容(分號(hào)、逗號(hào)除外),右側(cè)內(nèi)容與右花括號(hào)之間應(yīng)有空格。例如:

#define set_manager_index(x, idx) do { (x)- >priv- >index = (idx); } while (0)

manager_priv_t priv = { 0, NULL, };

分行定義的宏,\\與左側(cè)內(nèi)容之間應(yīng)有空格。例如:

#define set_manager_index(x, idx) \\
    do { \\
        (x)- >priv- >index = (idx); \\
    } while (0)

3.6. 指針

指針聲明或定義時(shí),*應(yīng)靠近變量名稱(chēng)。*與修飾符之間應(yīng)有空格。例如:

int *p;
const char *name;
void * const ptr;
void (*func)(void *arg);

3.7. 數(shù)值常量

十六進(jìn)制數(shù)字A ~ F使用大寫(xiě)形式。表示二進(jìn)制的前綴0b和表示十六進(jìn)制的0x使用小寫(xiě)形式。后綴UL使用大寫(xiě)形式。后綴f使用小寫(xiě)形式。表示冪的ep使用小寫(xiě)形式。例如:

unsigned int b = 0b0101;
unsigned int x = 0xABCDEF;
unsigned int u = 0U;
long int l = 0L;
unsigned long int ul = 0UL;
float f = 1.0f;
long double ld = 1.0L;
double dd = -1.5e-5;
double xd = 0xA.Bp12;

3.8. 注釋

使用C90風(fēng)格的/* */,不使用C++風(fēng)格的//。 /**/與注釋正文之間應(yīng)有空格。行尾的注釋和代碼之間應(yīng)有空格。完整語(yǔ)句注意首字母大寫(xiě)和標(biāo)點(diǎn)符號(hào),簡(jiǎn)單詞組可以不使用標(biāo)點(diǎn)。注意區(qū)分中英文標(biāo)點(diǎn)。 TODO: 使用特定注釋格式可利用doxygen等自動(dòng)化工具生成文檔。例如:

/*
 * This source file is part of AliOS Things.
 * Zhang San < zhangsan@example.com >
 * 2021.07.01
 */

/* Zhang San < zhangsan@example.com >
 * 2021.07.01 */

/* This pointer must NOT be NULL. */

/* connecting */

4. 頭文件

4.1. 路徑

為避免與第三方庫(kù)的頭文件命名沖突,公用組件的頭文件應(yīng)存放于子目錄中,引用時(shí)路徑包含子目錄名稱(chēng)。例如:

#include < aos/file.h >

4.2. 引號(hào)和尖括號(hào)

只有包含與本源文件處于同路徑中的頭文件時(shí)使用引號(hào),其他情況均使用尖括號(hào)。例如:

#include < stdio.h >
#include "my_demo.h"

4.3. 包含次序

包含頭文件的次序如下:|次序 |種類(lèi)| |-:- |:-| |1 |C語(yǔ)言標(biāo)準(zhǔn)庫(kù)頭文件和工具鏈頭文件| |2 |公用組件的頭文件| |3 |本工程頭文件|

例如:

#include < stdio.h >
#include < pthread.h >
#include < openssl/rsa.h >
#include < aos/headers.h >
#include "my_demo.h"

4.4. 保護(hù)

所有頭文件都應(yīng)該使用#define保護(hù)來(lái)防止被重復(fù)包含。相關(guān)宏命名格式是PATH_FILE_H。例如,頭文件aos/common.h可按如下方法保護(hù):

#ifndef AOS_COMMON_H
#define AOS_COMMON_H

/* 全部?jī)?nèi)容 */

#endif /* AOS_COMMON_H */

4.5. 函數(shù)、變量聲明

頭文件中的函數(shù)聲明不使用extern關(guān)鍵字。頭文件中的全局變量聲明使用extern關(guān)鍵字。例如:

void aos_cfg_file_close(int fd);
extern char **aos_process_argv;

4.6. extern "C"關(guān)鍵字

公用頭文件中聲明的函數(shù)和全局變量應(yīng)該使用extern "C"關(guān)鍵字修飾。 #include不應(yīng)使用extern "C"關(guān)鍵字修飾。 #define、類(lèi)型定義不作要求,可酌情考慮。例如:

#ifndef AOS_COMMON_H
#define AOS_COMMON_H

#include < stddef.h >

#define AOS_STRING_MAX_LEN      127
#define AOS_LSTRING_MAX_LEN     511

typedef struct aos_tm {
    unsigned int sec;
    unsigned int min;
    unsigned int hour;
    unsigned int mday;
    unsigned int mon;
    unsigned int year;
} aos_tm_t;

#ifdef __cplusplus
extern "C" {
#endif

extern char aos_process_symbol[AOS_STRING_MAX_LEN + 1];

void aos_start(void);

#ifdef __cplusplus
}
#endif

#endif /* AOS_COMMON_H */

5. 其他注意事項(xiàng)

只在本編譯單元使用的函數(shù)、全局變量應(yīng)使用static修飾符。在不影響功能的前提下,指針類(lèi)型的函數(shù)參數(shù)盡量使用const修飾符。自增、自減運(yùn)算符單獨(dú)使用時(shí)采用后置形式。數(shù)組、結(jié)構(gòu)體初始化列表、枚舉類(lèi)型定義中的最后一個(gè)成員之后應(yīng)有逗號(hào)。例如:

int offsets[] = {
    0,
    1,
};
聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • C語(yǔ)言
    +關(guān)注

    關(guān)注

    180

    文章

    7604

    瀏覽量

    136685
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4327

    瀏覽量

    62569
  • 代碼
    +關(guān)注

    關(guān)注

    30

    文章

    4779

    瀏覽量

    68521
收藏 人收藏

    評(píng)論

    相關(guān)推薦

    C語(yǔ)言規(guī)范標(biāo)準(zhǔn)

    C語(yǔ)言規(guī)范標(biāo)準(zhǔn),,,
    發(fā)表于 11-07 17:14

    華為C語(yǔ)言編程規(guī)范

    規(guī)范制定了編寫(xiě)C語(yǔ)言程序的基本原則、規(guī)則和建議。從代碼的清晰、簡(jiǎn)潔、可測(cè)試、安全、程序效率、可移植各個(gè)方面對(duì)C
    發(fā)表于 11-24 09:38

    C語(yǔ)言編程規(guī)范

    1、據(jù)說(shuō)是華為的C語(yǔ)言編程規(guī)范;2、本文件來(lái)自互聯(lián)網(wǎng)。
    發(fā)表于 02-22 16:36

    C語(yǔ)言代碼規(guī)范相關(guān)資料推薦

    C語(yǔ)言代碼規(guī)范參考安富萊C語(yǔ)言編碼規(guī)范1.文件與目錄
    發(fā)表于 12-14 08:30

    ARM C語(yǔ)言擴(kuò)展規(guī)范

    ARM C語(yǔ)言擴(kuò)展(ACLE)規(guī)范指定源語(yǔ)言擴(kuò)展和實(shí)現(xiàn)C/C++編譯器可以實(shí)現(xiàn)的選項(xiàng),以便讓程序
    發(fā)表于 08-02 06:27

    C語(yǔ)言編程規(guī)范

    C語(yǔ)言編程規(guī)范(僅供參考) 1. 基本要求1.1 程序結(jié)構(gòu)清析,簡(jiǎn)單易懂,單個(gè)函數(shù)的程序行數(shù)不得超過(guò)100行。1.2 打算干什么,要簡(jiǎn)單,直接了當(dāng),代碼精簡(jiǎn),避免垃圾
    發(fā)表于 11-08 09:53 ?740次閱讀

    C語(yǔ)言書(shū)寫(xiě)的常用規(guī)范

    C語(yǔ)言書(shū)寫(xiě)的常用規(guī)范
    發(fā)表于 10-26 10:43 ?26次下載
    <b class='flag-5'>C</b><b class='flag-5'>語(yǔ)言</b>書(shū)寫(xiě)的常用<b class='flag-5'>規(guī)范</b>

    C語(yǔ)言編寫(xiě)規(guī)范之注釋

    C語(yǔ)言變成規(guī)范
    發(fā)表于 05-24 14:36 ?13次下載

    華為的C語(yǔ)言編程規(guī)范的詳細(xì)資料說(shuō)明

    本文檔詳細(xì)介紹的是華為技術(shù)有限公司的C語(yǔ)言編程規(guī)范的詳細(xì)資料說(shuō)明。本規(guī)范制定了編寫(xiě)C語(yǔ)言程序的基
    發(fā)表于 03-06 08:00 ?31次下載
    華為的<b class='flag-5'>C</b><b class='flag-5'>語(yǔ)言</b>編程<b class='flag-5'>規(guī)范</b>的詳細(xì)資料說(shuō)明

    華為C語(yǔ)言編程規(guī)范

    關(guān)于華為C語(yǔ)言編程規(guī)范說(shuō)明免費(fèi)下載。
    發(fā)表于 06-23 14:47 ?61次下載

    C語(yǔ)言冒泡排序工程代碼匯總

    C語(yǔ)言冒泡排序工程代碼匯總
    發(fā)表于 08-30 11:06 ?3次下載

    C語(yǔ)言代碼中的extern

    在你的C語(yǔ)言代碼中,不知能否看到類(lèi)似下面的代碼: 這好像沒(méi)有什么問(wèn)題,你應(yīng)該還會(huì)想:“嗯?是啊,我們的代碼都是這樣寫(xiě)的,從來(lái)沒(méi)有因此碰到過(guò)什
    的頭像 發(fā)表于 09-02 15:13 ?2400次閱讀
    <b class='flag-5'>C</b><b class='flag-5'>語(yǔ)言</b><b class='flag-5'>代碼</b>中的extern

    178個(gè)經(jīng)典c語(yǔ)言代碼

    178個(gè)經(jīng)典c語(yǔ)言代碼分享
    發(fā)表于 11-17 16:57 ?173次下載

    嵌入式C語(yǔ)言編碼規(guī)范

    作為程序開(kāi)發(fā)者,避免不了閱讀別人代碼,那么就會(huì)涉及到到一門(mén)語(yǔ)言的編程規(guī)范。規(guī)范雖然不是語(yǔ)言本身的硬性要求,但是已經(jīng)是每一個(gè)
    的頭像 發(fā)表于 04-23 10:13 ?669次閱讀
    嵌入式<b class='flag-5'>C</b><b class='flag-5'>語(yǔ)言</b>編碼<b class='flag-5'>規(guī)范</b>

    嵌入式實(shí)時(shí)操作系統(tǒng)AliOS Things的編碼風(fēng)格介紹

    本文是AliOS Things提供的一套C語(yǔ)言代碼規(guī)范,適用的對(duì)象為符合C99標(biāo)準(zhǔn)的C
    的頭像 發(fā)表于 06-07 09:20 ?690次閱讀
    RM新时代网站-首页