- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
Q/WE 905-2005 《导弹武器系统C语言安全子集》 本标准完全遵循《GJB 5369-2005, 航天型号软件C语言安全子集》,并在二院型号软件工程实践的基础上,新补充了22条强制性准则和2条推荐性准则,将GJB航天型号软件C语言安全子集中的一条推荐性准则上升为强制性准则。附录B是相对于GJB航天型号软件C语言安全子集新增加的附录。 第六十二页,共一百二十四页。 准则分类 (1) 声明定义类 (2) 版面书写类 (3) 分支控制类 (4) 指针使用类 (5) 跳转控制类 (6) 运算处理类 (7) 过程调用类 (8) 语句使用类 (9) 调用返回类 (10) 程序注释类 (11) 循环控制类 (12) 类型转换类 (13) 初始化类 (14) 比较判断类 (15) 名称、符号与变量使用类 第六十三页,共一百二十四页。 4.1.1.15 字符型变量必须明确定义是有符号还是无符号 void static_p(void) { char c = c; /* ... */ } 违背 第六十四页,共一百二十四页。 4.1.1.20 禁止在#include ……中使用绝对路径名 #include C:\VC\include\stdio.h void Dummy(void) { /* ... */ } 头文件路径应该在编译器的选项中予以设置说明 违背 第六十五页,共一百二十四页。 4.2.1.2 循环体必须用大括号括起来 int static_p(int p_1) { int j = 10; int k = 0; /* ... */ for (k = 0; k 10; k = k + 1) j=j+1; return j; } 违背 第六十六页,共一百二十四页。 4.2.1.3 then/else中的语句必须用大括号括起来 (二院简化为: else中的语句必须用大括号括起来) int static_p(int p_1, int p_2) { int i = 1; int j = 2; /* ... */ if (p_1 0) { i = i - 1; } else i = i + 1; ? return i; } 违背 第六十七页,共一百二十四页。 4.2.1.4 逻辑表达式的连接必须使用括号 void static_p(void) { bool flag = true; unsigned int y = 0u, x = 0u, z = 1u; /* ... */ if (x 0 || z + y != 0 !flag) { flag = false; } } 违背 第六十八页,共一百二十四页。 4.2.1.5 禁止在头文件前有可执行代码 void static_p(void) { #include myfile.h /* ... */ } 违背 第六十九页,共一百二十四页。 4.2.1.6 宏参数必须用括号括起来 #define static_p(x) x = 0 ? x : -x void test_p(void) { unsigned int result; int a = 6, b = 5; /* ... */ result = static_p(a - b); result = static_p(a) + 1; /* ... */ } 违背 第七十页,共一百二十四页。 4.2.1.7 嵌入汇编程序的过程必须是纯汇编程序 void static_p(void) { unsigned int x; x = 0u; _asm { mov eax, x } } 违背 第七十一页,共一百二十四页。 4.2.1.9 禁止字符串中单独使用“\”而非“\0” (二院进一步明确为: 4.2.1.9 字符型数组赋值时,必须使用“\0”终止字符串) void static_p(void) { unsigned char str[5]; str[0]=a; str[1]=b; str[2]=c; /* 其它处理 */ } 违背 第七十二页,共一百二十四页。 4.3.1.1 禁止条件判别成立时相应分支无执行语句 void static_p(void) { unsigned int value_x = 1u; /* ... */ if (value_x == 0u)
您可能关注的文档
最近下载
- 新入职保安培训知识课件.pptx VIP
- Unit5 a cherry, please(课件)译林版(一起)英语一年级上册.pptx
- OEE计算表格(完整工具).xls VIP
- 食品生产企业有害生物风险管理指南.docx VIP
- 《计算机控制系统》课后题答案-刘建昌.pdf VIP
- 2025年医学课件-转变围术期麻醉管理理念推进ERAS加速康复外科建设.pptx VIP
- 加强县级行政事业单位房地资产管理的思考.doc VIP
- 2024人民防空工程常见技术问题及解答.docx VIP
- 人教版鄂教版科学二年级上册二单元《水和空气》大单元教学设计.pdf VIP
- T_GDPAWS 33-2024 城镇污水处理企业应急能力建设规范.docx VIP
原创力文档


文档评论(0)