1 / 84
文档名称:

华为程序设计规范.doc

格式:doc   大小:160KB   页数:84页
下载后只包含 1 个 DOC 格式的文档,没有任何的图纸或源代码,查看文件列表

如果您已付费下载过本站文档,您可以点这里二次下载

分享

预览

华为程序设计规范.doc

上传人:1314042**** 2021/1/18 文件大小:160 KB

下载得到文件列表

华为程序设计规范.doc

相关文档

文档介绍

文档介绍:1 排版 2
2 注释 11
3 标识符命名 23
4 可读性 27
5 变量、结构 30
6 函数、过程 42
7 可测性 57
8 程序效率 65
9 质量保证 72
10 代码编辑、编译、审查 84
11 代码测试、维护 86
12 宏 87
1 排版(不要追求所谓的紧凑风格—更不要卖弄技巧)
1-1:程序块要采用缩进风格编写,缩进的空格数为4个。
说明:对于由开发工具自动生成的代码可以有不一致。
1-2:相对独立的程序块之间、变量说明之后必须加空行。
示例:如下例子不符合规范。
if (!valid_ni(ni))
{
    // program code
}
repssn_ind = ssn_data[index]repssn_index;
repssn_ni  = ssn_data[index]ni; 
应如下书写
if (!valid_ni(ni))
{
    // program code
}
 
repssn_ind = ssn_data[index]repssn_index;
repssn_ni  = ssn_data[index]ni;
1-3:较长的语句(>80字符)要分成多行书写,长表达式要在低优先级操作符处划分新行,操作符放在新行之首,划分出的新行要进行适当的缩进,使排版整齐,语句可读。
示例:
perm_count_msgheadlen = NO7_TO_STAT_PERM_COUNT_LEN
                          + STAT_SIZE_PER_FRAM * sizeof( _UL );
 
act_task_table[frame_id * STAT_TASK_CHECK_NUMBER + index]occupied
              = stat_poi[index]occupied;
 
act_task_table[taskno]duration_true_or_false
              = SYS_get_sccp_statistic_state( stat_item );
 
report_or_not_flag = ((taskno < MAX_ACT_TASK_NUMBER)
                      && (n7stat_stat_item_valid (stat_item))
                      && (act_task_table[taskno]result_data != 0));
1-4:循环、判断等语句中若有较长的表达式或语句,则要进行适应的划分,长表达式要在低优先级操作符处划分新行,操作符放在新行之首。
示例:
if ((taskno < max_act_task_number)
    && (n7stat_stat_item_valid (stat_item)))
{
    // program code
}
 
for (i = 0, j = 0; (i < BufferKeyword[word_index]word_length)
                    && (j < NewKeywordword_length); i++, j++)
{
    // program code
}
 
for (i = 0, j = 0; 
     (i < first_word_length) && (j < second_word_length); 
     i++, j++)
{
    // program code
}
1-5:若函数或过程中的参数较长,则要进行适当的划分。
示例:
n7stat_str_compare((BYTE *) & stat_object,
                   (BYTE *) & (act_task_table[taskno]stat_object),
                   sizeof (_STAT_OBJECT));
 
n7stat_flash_act_duration( stat_item, frame_id * STAT_TASK_CHECK_NUMBER
                                      + index, stat_object );
1-6:不允许把多个短语句写在一行中,即一行只写一条语句。
示例:如下例子不符合规范。
rectlen