大型公司笔试题目汇总(3)——创维数字笔试题目精华版 收藏
这是当时面创维数字的笔试题,题目比较简单,只涉及到了基本的C语法,没有考到数据结构以及算法,试题在前面说明这套题并不能反映应聘者实际的软件开发及编程能力。
一、请填写BOOL , float, 指针变量 与“零值”比较的 if 语句。(10分)
二、以下为Windows NT下的32位C++程序,请计算sizeof的值(10分)
三、简答题(25分)
1、头文件中的 ifndef/define/endif 干什么用?(5分)
答:防止该头文件被重复引用。
2、#include <filename.h> 和 #include “filename.h” 有什么区别?(5分)
答:对于#include <filename.h> ,编译器从标准库路径开始搜索 filename.h
对于#include “filename.h” ,编译器从用户的工作路径开始搜索 filename.h
3、const 有什么用途?(请至少说明两种)(5分)
答:
(1) 可以定义 const 常量
(2) const可以修饰函数的参数、返回值,甚至函数的定义体。被const修饰的东西都受到强制保护,可以预防意外的变动,能提高程序的健壮性。
4、在C++ 程序中调用被 C编译器编译后的函数,为什么要加 extern “C”? (5分)
答:C++语言支持函数重载,C语言不支持函数重载。函数被C++编译后在库中的名字与C语言的不同。假设某个函数的原型为: void foo(int x, int y);
该函数被C编译器编译后在库中的名字为_foo,而C++编译器则会产生像_foo_int_int之类的名字。
C++提供了C连接交换指定符号extern“C”来解决名字匹配问题。
四、有关内存的思考题(每小题5分,共20分)
一.
请问运行Test函数会有什么样的结果?
答:试题传入GetMemory( char *p )函数的形参为字符串指针,在函数内部修改形参并不能真正的改变传入形参的值,执行完 char *str = NULL; GetMemory( str ); 后的str仍然为NULL;
二.
请问运行Test函数会有什么样的结果?
答:可能是乱码。 char p[] = "hello world"; return p; 的p[]数组为函数内的局部自动变量,在函数返回后,内存已经被释放。这是许多程序员常犯的错误,其根源在于不理解变量的生存期。
三.
请问运行Test函数会有什么样的结果?
答:
(1) 能够输出hello (2)Test函数中也未对malloc的内存进行释放。(3) GetMemory避免了试题1的问题,传入GetMemory的参数为字符串指针的指针,但是在GetMemory中执行申请内存及赋值语句
p = (char *) malloc( num );
后未判断内存是否申请成功,应加上:
四.
请问运行Test函数会有什么样的结果?
答:执行 char *str = (char *) malloc(100); 后未进行内存是否申请成功的判断;另外,在free(str)后未置str为空,导致可能变成一个“野”指针,应加上: str = NULL;
五、编写strcpy函数(10分)
已知strcpy函数的原型是 char *strcpy(char *strDest, const char *strSrc);// 其中strDest是目的字符串,strSrc是源字符串。
(1) 不调用C++/C的字符串库函数,请编写函数 strcpy
(2) strcpy能把strSrc的内容复制到strDest,为什么还要char * 类型的返回值?
答:为了实现链式表达式。 // 2分
例如 int length = strlen( strcpy( strDest, “hello world”) );
六、编写类String的构造函数、析构函数和赋值函数(25分)
已知类String的原型为:
请编写String的上述4个函数。
标准答案:
String的普通构造函数
拷贝构造函数
赋值函数