C语言编程规范试题(标准答案)
2015-07-31 09:33
483 查看
C语言编程规范试题(标准答案)
一.单选题(每小题3分,共20小题60分)
1.1-1.5 B D A C B 1.6-1.10 C A D B C
1.11-1.15 A D D C B 1.16-1.20 D A B C A
二.填空题(每空1分,共20空20分)
2.1 通常在设计函数的时候,函数之间要低 耦合 ,函数内部要高 内聚 ,函数之间调用关系要 高 扇入、 合理 扇出。
2.2 为了提高代码的效率,通常要求循环体内工作量 最小化 ,把多重循环中最忙的循环放在 最内层 。
2.3 代码质量保证优先原则中,最优先保证 正确性 ,然后依次是稳定性、安全性、 可测试性 、规范/可读性、全局效率、局部效率、个人方便性。
2.4 代码走读主要是对程序的编程风格如注释、命名等以及编程时易出错的内容进行检查,可由开发人员自己或开发人员 交叉 的方式进行;代码审查主要是对程序实现的功能及程序的稳定性、安全性、可靠性等进行检查及评审,可通过自审、 交叉审核 或 指定部门抽查 等方式进行。
2.5同产品软件(项目组)内,最好使用相同的编辑器,并使用相同的 设置选项 。
2.6资源文件(多语言版本支持),如果资源是对语言敏感的,应让该资源与源代码文件 脱离 ,具体方法有下面几种: 使用单独的资源文件 、 DLL文件 或其它单独的描述文件(如数据库格式)。
2.7对较关键的算法最好使用 其它算法 来确认。
2.8局部效率应为 全局效率 服务,不能因为提高局部效率而对 全局效率 造成影响。
2.9在同一项目组或产品组内,要有一套统一的为集成测试与系统联调准备的 调测开关 及相应打印函数,并且要有详细的说明。
2.10检查函数所有参数输入的有效性,同时还要检查函数所有非参数输入的有效性,如数据文件、 公共变量 等。
三.编程题(每小题20分,共1小题20分)
3.1 编写函数实现:将整型变成字符串,如3489变成"3489"。要求不可以使用任何C库函数。函数原型声明如下:
char *intTostring(int num, char *result);
答题评分标准:
1、 结果完全正确:15分
2、 结果完全不正确:0分
3、 结果部分正确:如未考虑负数的情况,得8分
4、 结果完全正确或部分正确的情况下,考查编程规范符合情况,加0~5分
5、 结果完全不正确的情况下,即使编程规范完全符合,亦不可加分。
参考程序:
char *intTostring(int num, char *result)
{
char buf[15];
int i = 0;
int n = 0;
int k = 0;
int tmpNum = num;
if (tmpNum >= 0)
{
// 正数
k = 1;
}
else
{
// 负数
k = 0;
tmpNum = -tmpNum;
}
do
{
buf[i++] = tmpNum % 10 + '0';
tmpNum = tmpNum / 10;
}while(tmpNum);
if (0 == k)
{
buf[i++] = '-';
}
// 顺序颠倒回来
for (n = i - 1; n >= 0; n--)
{
result[i - 1 - n] = buf
;
}
result[i] = '\0';
return result;
}
一.单选题(每小题3分,共20小题60分)
1.1-1.5 B D A C B 1.6-1.10 C A D B C
1.11-1.15 A D D C B 1.16-1.20 D A B C A
二.填空题(每空1分,共20空20分)
2.1 通常在设计函数的时候,函数之间要低 耦合 ,函数内部要高 内聚 ,函数之间调用关系要 高 扇入、 合理 扇出。
2.2 为了提高代码的效率,通常要求循环体内工作量 最小化 ,把多重循环中最忙的循环放在 最内层 。
2.3 代码质量保证优先原则中,最优先保证 正确性 ,然后依次是稳定性、安全性、 可测试性 、规范/可读性、全局效率、局部效率、个人方便性。
2.4 代码走读主要是对程序的编程风格如注释、命名等以及编程时易出错的内容进行检查,可由开发人员自己或开发人员 交叉 的方式进行;代码审查主要是对程序实现的功能及程序的稳定性、安全性、可靠性等进行检查及评审,可通过自审、 交叉审核 或 指定部门抽查 等方式进行。
2.5同产品软件(项目组)内,最好使用相同的编辑器,并使用相同的 设置选项 。
2.6资源文件(多语言版本支持),如果资源是对语言敏感的,应让该资源与源代码文件 脱离 ,具体方法有下面几种: 使用单独的资源文件 、 DLL文件 或其它单独的描述文件(如数据库格式)。
2.7对较关键的算法最好使用 其它算法 来确认。
2.8局部效率应为 全局效率 服务,不能因为提高局部效率而对 全局效率 造成影响。
2.9在同一项目组或产品组内,要有一套统一的为集成测试与系统联调准备的 调测开关 及相应打印函数,并且要有详细的说明。
2.10检查函数所有参数输入的有效性,同时还要检查函数所有非参数输入的有效性,如数据文件、 公共变量 等。
三.编程题(每小题20分,共1小题20分)
3.1 编写函数实现:将整型变成字符串,如3489变成"3489"。要求不可以使用任何C库函数。函数原型声明如下:
char *intTostring(int num, char *result);
答题评分标准:
1、 结果完全正确:15分
2、 结果完全不正确:0分
3、 结果部分正确:如未考虑负数的情况,得8分
4、 结果完全正确或部分正确的情况下,考查编程规范符合情况,加0~5分
5、 结果完全不正确的情况下,即使编程规范完全符合,亦不可加分。
参考程序:
char *intTostring(int num, char *result)
{
char buf[15];
int i = 0;
int n = 0;
int k = 0;
int tmpNum = num;
if (tmpNum >= 0)
{
// 正数
k = 1;
}
else
{
// 负数
k = 0;
tmpNum = -tmpNum;
}
do
{
buf[i++] = tmpNum % 10 + '0';
tmpNum = tmpNum / 10;
}while(tmpNum);
if (0 == k)
{
buf[i++] = '-';
}
// 顺序颠倒回来
for (n = i - 1; n >= 0; n--)
{
result[i - 1 - n] = buf
;
}
result[i] = '\0';
return result;
}
相关文章推荐
- C语言编程规范试题
- C/C++基本知识(三)
- 模拟实现C语言中的内存管理
- C/C++基本知识(二)
- C语言常见函数(备忘录)
- C++实现八个常用的排序算法:插入排序、冒泡排序、选择排序、希尔排序等
- C++如何生成自己的静态库(lib)文件
- C++ inline和#define宏的区别
- c/c++常用的几个关键字总结
- C语言中的内存管理
- 黑马程序员---iOS基础---C语言中的指针
- [C++11]新特性试用
- c-ares 一个C语言的异步DNS解析库
- VC++ MFC 按钮的全部样式Style
- oc语言第七课 内存管理一——ios学习连载12
- C语言的历史
- 【C语言探索之旅】 第二部分第十课:练习题和习作
- 黑马程序员--学习C语言文件操作
- 插入排序、冒泡排序、选择排序、希尔排序、快速排序、归并排序、堆排序和LST基数排序——C++实现
- C语言播放MP3音乐