【华为编程规范】对编程习惯很有帮助

上传者: czyt1988 | 上传时间: 2025-07-04 20:32:54 | 文件大小: 264KB | 文件类型: PDF
### 华为编程规范知识点详解 #### 一、排版规范 华为的编程规范非常重视代码的排版,这是为了确保代码的清晰性和可读性。以下是对文档中提到的一些关键排版规则的详细解释: 1. **程序块缩进**(¹1-1): - 规则说明:程序块应当采用缩进风格编写,每一级缩进使用4个空格。 - 示例不符合规范: ```c if(!valid_ni(ni)) { //programcode } repssn_ind = ssn_data[index].repssn_index; repssn_ni = ssn_data[index].ni; ``` - 正确示范: ```c if (!valid_ni(ni)) { // programcode } repssn_ind = ssn_data[index].repssn_index; repssn_ni = ssn_data[index].ni; ``` 2. **程序块之间的空行**(¹1-2): - 规则说明:相对独立的程序块之间、变量声明之后必须加空行。 - 示例不符合规范: ```c if(!valid_ni(ni)) { //programcode } repssn_ind = ssn_data[index].repssn_index; repssn_ni = ssn_data[index].ni; ``` - 正确示范: ```c if (!valid_ni(ni)) { // programcode } repssn_ind = ssn_data[index].repssn_index; repssn_ni = ssn_data[index].ni; ``` 3. **长语句的拆分**(¹1-3): - 规则说明:如果语句长度超过80个字符,应当在低优先级操作符处将语句拆分为多行,并将操作符置于新行开头。 - 示例不符合规范: ```c perm_count_msg.head.len = 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)); ``` - 正确示范: ```c perm_count_msg.head.len = 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)); ``` 4. **长表达式的拆分**(¹1-4): - 规则说明:循环、判断等语句中若有较长的表达式,则需在低优先级操作符处进行适当的划分。 - 示例不符合规范: ```c if ((taskno < max_act_task_number) && (n7stat_stat_item_valid(stat_item))) { // programcode } for (i = 0, j = 0; (i < BufferKeyword[word_index].word_length) && (j < NewKeyword.word_length); i++, j++) { // programcode } ``` - 正确示范: ```c if ((taskno < max_act_task_number) && (n7stat_stat_item_valid(stat_item))) { // programcode } for (i = 0, j = 0; (i < BufferKeyword[word_index].word_length) && (j < NewKeyword.word_length); i++, j++) { // programcode } ``` 5. **函数参数的拆分**(¹1-5): - 规则说明:如果函数调用中的参数过长,则需要适当拆分。 - 示例不符合规范: ```c n7stat_str_compare((BYTE*) &stat_object, (BYTE*) &(act_task_table[taskno].stat_object), sizeof(_STAT_OBJECT)); ``` - 正确示范: ```c n7stat_str_compare((BYTE*) &stat_object, (BYTE*) &(act_task_table[taskno].stat_object), sizeof(_STAT_OBJECT)); ``` 6. **单行语句**(¹1-6): - 规则说明:每个语句都应单独占据一行。 - 示例不符合规范: ```c rect.length = 0; rect.width = 0; ``` - 正确示范: ```c rect.length = 0; rect.width = 0; ``` 7. **控制语句格式**(¹1-7): - 规则说明:`if`、`for`、`do`、`while`、`case`、`switch`、`default`等语句自占一行,其后的执行语句无论长度如何都必须加括号 `{}`。 - 示例不符合规范: ```c if (pUserCR == NULL) return; ``` - 正确示范: ```c if (pUserCR == NULL) { return; } ``` 8. **后续规范待续**(¹1-8): - 规则说明:文档中未给出具体规范,但可以推测该部分继续讲解关于排版的其他规范。 以上是华为编程规范中关于排版方面的主要规定。这些规范旨在提高代码的可读性和可维护性,确保代码的一致性和标准化。遵循这些规范有助于减少错误的发生,提高团队协作效率。

文件下载

评论信息

免责申明

【只为小站】的资源来自网友分享,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,【只为小站】 无法对用户传输的作品、信息、内容的权属或合法性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论 【只为小站】 经营者是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。
本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二条之规定,若资源存在侵权或相关问题请联系本站客服人员,zhiweidada#qq.com,请把#换成@,本站将给予最大的支持与配合,做到及时反馈和处理。关于更多版权及免责申明参见 版权及免责申明