2022年2022年计算机专业面试题目 .pdf





《2022年2022年计算机专业面试题目 .pdf》由会员分享,可在线阅读,更多相关《2022年2022年计算机专业面试题目 .pdf(18页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、计算机专业面试题集计算机随笔2008-05-05 19:28:18 阅读 2083 评论 0 字号:大中小 订阅一些面试准备题(包括高质量c+题)const char*, char const*, char*const的区别问题几乎是 C+面试中每次都会有的题目。事实上这个概念谁都有只是三种声明方式非常相似很容易记混。Bjarne 在他的 The C+ Programming Language里面给出过一个助记的方法:把一个声明从右向左读。char * const cp; ( * 读成 pointer to ) const cp指向字符串;即指向字符串的常指针;const char * p;
2、p 指向字符串常量,即指向字符串常量的指针;char const * p; 这个和上面的事一样的,表达的意思也是指向字符串常量的指针同上因为 C+里面没有 const*的运算符,所以 const只能属于前面的类型。下面这个程序执行后会有什么错误或者效果: #define MAX 255 int main() unsigned char AMAX,i; for (i=0;i=MAX;i+) Ai=i; 解答:MAX=255 数组 A 的下标范围为 :0.MAX-1, 这是其一 . 其二.当 i 循环到 255时,循环内执行 : A255=255; 这句本身没有问题 .但是返回 for (i=0;
3、i=MAX;i+)语句时 , 由于 unsigned char的取值范围在 (0.255),i+以后 i 又为 0 了.无限循环下去 . 注:char类型为一个字节,取值范围是-128,127,unsigned char 0 ,255 编写用 C 语言实现的求 n 阶阶乘问题的递归算法: *仅仅只要是一个算法就 ok,不用管那么多,能用就行。long int fact(int n) int x; long int y; if(n0) printf(error!); 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 -
4、 - - - - - - 第 1 页,共 18 页 - - - - - - - - - if(n=0) return 1; x=n-1; y=fact(x); /这是一个递归调用过程,return (n*y); Long int fact(int n) If(nhigh) return -1;/error mid=(low+high)/2; if(x=amid) return mid; if(xhigh) Return -1; Mid=(low+high)/2; If(x=amid) Return mid; If(xmid) return base(a,x,low,mid-1); Elae r
5、eturn base(a,x,mid+1,high); 2、非递归方法实现:int BSearch(elemtype a,keytype key,int n) 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 2 页,共 18 页 - - - - - - - - - int low,high,mid; low=0;high=n-1; while(low=high) mid=(low+high)/2; if(amid.key=key) return mid; else if(amid.k
6、ey2 解:int f(int n) int i,s,s1,s2; s1=1;/*s1 用于保存 f(n-1)的值*/ s2=1;/*s2 用于保存 f(n-2)的值*/ s=1; for(i=3;i= - EPSINON) & (x =”或“=”此类形式。如下是错误的写法,不得分。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 (!) 二、以下为 Wind
7、ows NT 下的 32 位 C+程序,请计算 sizeof 的值( 10 分)void Func ( char str100) 请计算sizeof( str ) = 4 (2 分) char str = “Hello ” ;char *p = str ; int n = 10; 请计算sizeof (str ) = 6 (2 分)sizeof ( p ) = 4 (2 分)sizeof ( n ) = 4 (2 分)名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 7 页,共 18
8、页 - - - - - - - - - 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.h 3、const 有什么用途?(请至少说明两种) (5 分
9、)答: (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 连接交换指定符
10、号extern “C”来解决名字匹配问题。5、请简述以下两个for 循环的优缺点( 5 分)for (i=0; iN; i+) if (condition) DoSomething(); else DoOtherthing(); if (condition) for (i=0; iN; i+) DoSomething(); else for (i=0; iN; i+) DoOtherthing(); 优点:程序简洁缺点:多执行了 N-1 次逻辑判断,并且打断了循环 “ 流水线 ” 作业,使得编译器不能对循环进行优化处理,降低了效名师资料总结 - - -精品资料欢迎下载 - - - - - -
11、- - - - - - - - - - - - 名师精心整理 - - - - - - - 第 8 页,共 18 页 - - - - - - - - - 率。优点:循环的效率高缺点:程序不简洁四、有关内存的思考题(每小题5 分,共 20 分)void GetMemory(char *p) p = (char *)malloc(100); void Test(void) char *str = NULL; GetMemory(str); strcpy(str, hello world); printf(str); 请问运行 Test 函数会有什么样的结果?答:程序崩溃。因为 GetMemory 并
12、不能传递动态内存,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(str); 请问运行 Test 函数会有什么样的结果?答:可能是乱码。因为 GetMemory 返回的是指向 “ 栈内存 ”的指针,该指针的地址不是NULL ,但其原现的内容已经被清除,新内容不可知。void GetMemory2(char
13、*p, int num) *p = (char *)malloc(num); void Test(void) 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 9 页,共 18 页 - - - - - - - - - char *str = NULL; GetMemory(&str, 100); strcpy(str, hello); printf(str); 请问运行 Test 函数会有什么样的结果?答:(1)能够输出 hello (2)内存泄漏void Test(void) cha
14、r *str = (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); 其中
15、strDest 是目的字符串, strSrc 是源字符串。(1)不调用 C+/C 的字符串库函数,请编写函数strcpy char *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, 为什么还要
16、 char * 类型的返回值?答:为了实现链式表达式。/ 2 分例如 int length = strlen( strcpy( strDest, “hello world”) );六、编写类 String 的构造函数、析构函数和赋值函数(25 分)已知类 String 的原型为:class String 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 10 页,共 18 页 - - - - - - - - - public: String(const char *str = NULL
17、); / 普通构造函数String(const String &other); / 拷贝构造函数 String(void); / 析构函数String & operate =(const String &other); / 赋值函数private: char *m_data; / 用于保存字符串; 请编写 String 的上述 4 个函数。标准答案:/ String 的析构函数String:String(void) / 3 分 delete m_data; / 由于 m_data 是内部数据类型,也可以写成delete m_data; / String 的普通构造函数String:String
18、(const char *str) / 6 分 if(str=NULL) m_data = new char1; / 若能加 NULL 判断则更好*m_data = , 0?; else int length = strlen(str); m_data = new charlength+1; / 若能加 NULL 判断则更好strcpy(m_data, str); / 拷贝构造函数String:String(const String &other) / 3 分 int length = strlen(other.m_data); m_data = new charlength+1; / 若能加
19、 NULL 判断则更好strcpy(m_data, other.m_data); / 赋值函数String & String:operate =(const String &other) / 13 分 / (1) 检查自赋值/ 4 分if(this = &other) 名师资料总结 - - -精品资料欢迎下载 - - - - - - - - - - - - - - - - - - 名师精心整理 - - - - - - - 第 11 页,共 18 页 - - - - - - - - - return *this; / (2) 释放原有的内存资源/ 3 分delete m_data; / (3)分
20、配新的内存资源,并复制内容/ 3 分int length = strlen(other.m_data); m_data = new charlength+1; / 若能加 NULL 判断则更好strcpy(m_data, other.m_data); / (4)返回本对象的引用/ 3 分return *this; winsocket 编程#include #include void main() WORDwVersionRequested; WSADATA wsaData; int err; wVersionRequested = MAKEWORD(1,1); err = WSAStartup
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 2022年2022年计算机专业面试题目 2022 计算机专业 面试 题目

限制150内