- 1、本文档共34页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
华为软件编程规范和范例【荐】.doc
华为软件编程规范和范例
〔一〕=====[排版] ]=======. 〔二〕======[注释]=======. 〔三〕=====[标识符命名]=======. 〔四〕=====[可读性]======. 〔五〕=====[变量、结构]=====. 〔六〕=====[函数、过程]=====. 〔七〕=====[可测性]=====. 〔八〕=====[程序效率]=====. 〔九〕=====[质量保证]=====. 〔十〕=====[代码编辑、编译、审查]=====. 〔十一〕=====[代码测试、维护]=====. 〔十二〕=====[宏]=====.
?
〔一〕 =====[ 排版 ]
11-1 :程序块要采用缩进风格编写,缩进的空格数为4 个
说明:对于由开发工具自动生成的代码可以有不一致。
11-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;
11-3 :较长的语句(80 字符)要分成多行书写,长表达式要在低优先级操作符处划分新行,操作符放在新行之首,划分出的新行要进行适当的缩进,使排版整齐,语句可读
示例:
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));
11-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 NewKeyword.word_length); i++, j++)
{
??? ... // program code
}
for (i = 0, j = 0;?
???? (i first_word_length) (j second_word_length);?
???? i++, j++)
{
??? ... // program code
}
11-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
????????????????????????????????
您可能关注的文档
最近下载
- 2025年东莞市南开实验学校高一入学分班考试语文作文猜题及范文分析.docx
- 中国成人念珠菌病诊断与治疗专家共识解读PPT课件.pptx VIP
- 野生菌中毒护理查房.pptx VIP
- 年产2万吨生物基全降解塑料项目可行性研究报告.docx
- FIDIC 认证项目经理水平考试试卷与答案.doc
- 48V100A储能电池BMS规格书(带10A限流)CAN+RS485.docx VIP
- 中国教育史(近代)课件.ppt VIP
- 2005年广东高考物理试卷真题及答案.doc VIP
- 2005年高考数学(广东卷)试题及答案.doc VIP
- (高清版)DB41∕T 1432-2017 精密耐震压力表.pdf VIP
文档评论(0)