1、C+/C试题本试题仅用于考查C+/C程序员的基本编程技能。内容限于C+/C常用语法,不包括数据结构、算法以及深奥的语法。考试成绩能反应出考生的编程质量以及对C+/C的了解程度,但不能反应考生的智力和软件开发能力。笔试时间90分钟。请考生仔细答题,切勿轻视。一、请填写BOOL , float, 指针变量 与“零值”比较的 if 语句。(10分)提示:这里“零值”能够是0, 0.0 , FALSE或者“空指针”。例如 int 变量 n 与“零值”比较的 if 语句为:if ( n = 0 )if ( n != 0 )以此类推。请写出 BOOLflag 与“零值”比较的 if 语句:请写出 floa
2、tx 与“零值”比较的 if 语句:请写出 char*p 与“零值”比较的 if 语句:二、如下为Windows NT下的32位C+程序,请计算sizeof的值(10分)charstr = “Hello” ;char*p = str ;intn = 10;请计算sizeof (str ) =sizeof ( p ) =sizeof ( n ) =void Func ( char str100)请计算sizeof( str ) =void *p = malloc( 100 );请计算sizeof ( p ) =三、简答题(25分)1、头文献中的 ifndef/define/endif 干什么用?
3、 2、#include和#include“filename.h” 有什么区分? 3、const 有什么用途?(请最少阐明两种) 4、在C+ 程序中调用被 C编译器编译后的函数,为何要加 extern “C”申明?5、请简述如下两个for循环的优缺陷/ 第一个for (i=0; iN; i+)if (condition)DoSomething();elseDoOtherthing();/ 第二个if (condition)for (i=0; iN; i+)DoSomething();elsefor (i=0; i= - EPSINON) & (x =”或“=”此类形式。如下是错误的写法,不得分。
4、if (x = 0.0)if (x != 0.0)请写出 char*p 与“零值”比较的 if 语句。(3分)标准答案:if (p = NULL)if (p != NULL)如下写法均属不良格调,不得分。if (p = 0) if (p != 0)if (p)if (!)二、如下为Windows NT下的32位C+程序,请计算sizeof的值(10分)charstr = “Hello” ;char*p = str ;intn = 10;请计算sizeof (str ) =6(2分) sizeof ( p ) =4(2分)sizeof ( n ) =4(2分)void Func ( char s
5、tr100)请计算sizeof( str ) =4(2分)void *p = malloc( 100 );请计算sizeof ( p ) =4(2分)三、简答题(25分)1、头文献中的 ifndef/define/endif 干什么用?(5分)答:预防该头文献被重复引用。2、#include和#include“filename.h” 有什么区分?(5分)答:对于#include ,编译器从标准库途径开始搜索 filename.h对于#include“filename.h” ,编译器从用户的工作途径开始搜索 filename.h3、const 有什么用途?(请最少阐明两种)(5分)答:(1)能够
6、定义 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、请简述如下
7、两个for循环的优缺陷(5分)for (i=0; iN; i+)if (condition)DoSomething();elseDoOtherthing();if (condition)for (i=0; iN; i+)DoSomething();elsefor (i=0; iN; i+)DoOtherthing();优点:程序简洁缺陷:多执行了N-1次逻辑判断,并且打断了循环“流水线”作业,使得编译器不能对循环进行优化处理,减少了效率。优点:循环的效率高缺陷:程序不简洁四、有关内存的思考题(每题5分,共20分)void GetMemory(char *p)p = (char *)malloc
8、(100);void Test(void) char *str = NULL;GetMemory(str);strcpy(str, hello world);printf(str);请问运行Test函数会有什么样的成果?答:程序瓦解。因为GetMemory并不能传递动态内存,Test函数中的 str一直都是 NULL。strcpy(str, hello world);将使程序瓦解。char *GetMemory(void)char p = hello world;return p;void Test(void)char *str = NULL;str = GetMemory();printf(
9、str);请问运行Test函数会有什么样的成果?答:也许是乱码。因为GetMemory返回的是指向“栈内存”的指针,该指针的地址不是 NULL,但其原现的内容已经被清除,新内容不可知。void GetMemory2(char *p, int num)*p = (char *)malloc(num);void Test(void)char *str = NULL;GetMemory(&str, 100);strcpy(str, hello);printf(str);请问运行Test函数会有什么样的成果?答:(1)能够输出hello(2)内存泄漏void Test(void)char *str =
10、 (char *) malloc(100);strcpy(str, “hello”);free(str);if(str != NULL) strcpy(str, “world”); printf(str);请问运行Test函数会有什么样的成果?答:篡改动态内存区的内容,后果难以预料,非常危险。因为free(str);之后,str成为野指针,if(str != NULL)语句不起作用。五、编写strcpy函数(10分)已知strcpy函数的原型是char *strcpy(char *strDest, const char *strSrc);其中strDest是目标字符串,strSrc是源字符串。
11、(1)不调用C+/C的字符串库函数,请编写函数 strcpychar *strcpy(char *strDest, const char *strSrc);assert(strDest!=NULL) & (strSrc !=NULL); / 2分char *address = strDest;/ 2分while( (*strDest+ = * strSrc+) != 0 )/ 2分NULL ; return address ;/ 2分(2)strcpy能把strSrc的内容复制到strDest,为何还要char * 类型的返回值?答:为了实现链式体现式。/ 2分例如int length = s
12、trlen( strcpy( strDest, “hello world”) );六、编写类String的结构函数、析构函数和赋值函数(25分)已知类String的原型为:class Stringpublic:String(const char *str = NULL); / 一般结构函数String(const String &other);/ 拷贝结构函数 String(void);/ 析构函数String & operate =(const String &other);/ 赋值函数private:char*m_data;/ 用于保存字符串;请编写String的上述4个函数。标准答案:/
13、 String的析构函数String:String(void)/ 3分delete m_data; / 因为m_data是内部数据类型,也能够写成 delete m_data;/ String的一般结构函数String:String(const char *str)/ 6分if(str=NULL)m_data = new char1;/ 若能加 NULL 判断则愈加好*m_data = 0;elseint length = strlen(str);m_data = new charlength+1;/ 若能加 NULL 判断则愈加好strcpy(m_data, str);/ 拷贝结构函数Str
14、ing:String(const String &other)/ 3分int length = strlen(other.m_data); m_data = new charlength+1;/ 若能加 NULL 判断则愈加好strcpy(m_data, other.m_data);/ 赋值函数String & String:operate =(const String &other)/ 13分/ (1) 检查自赋值/ 4分if(this = &other)return *this;/ (2) 释放原有的内存资源/ 3分delete m_data;/ (3)分派新的内存资源,并复制内容 / 3分int length = strlen(other.m_data); m_data = new charlength+1;/ 若能加 NULL 判断则愈加好strcpy(m_data, other.m_data);/ (4)返回本对象的引用 / 3分return *this;