ImageVerifierCode 换一换
格式:DOCX , 页数:33 ,大小:43.29KB ,
资源ID:6440908      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/6440908.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(常见c++笔试题整理含答案.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

常见c++笔试题整理含答案.docx

1、常见c+笔试题整理含答案1.是不是一个父类写了一个virtual 函数,如果子类覆盖它的函数不加virtual ,也能实现多态?virtual修饰符会被隐形继承的。private 也被集成,只事派生类没有访问权限而已。virtual可加可不加。子类的空间里有父类的所有变量(static除外)。同一个函数只存在一个实体(inline除外)。子类覆盖它的函数不加virtual ,也能实现多态。在子类的空间里,有父类的私有变量。私有变量不能直接访问。-2.输入一个字符串,将其逆序后输出。(使用C+,不建议用伪码)#include using namespace std;void main()char

2、 a50;memset(a,0,sizeof(a);int i=0,j;char t;cin.getline(a,50,n);for(i=0,j=strlen(a)-1;istrlen(a)/2;i+,j-) t=ai; ai=aj; aj=t;coutastr;str.replace;coutstr;-3.请简单描述Windows内存管理的方法。内存管理是操作系统中的重要部分,两三句话恐怕谁也说不清楚吧我先说个大概,希望能够抛砖引玉吧当程序运行时需要从内存中读出这段程序的代码。代码的位置必须在物理内存中才能被运行,由于现在的操作系统中有非常多的程序运行着,内存中不能够完全放下,所以引出了虚拟

3、内存的概念。把哪些不常用的程序片断就放入虚拟内存,当需要用到它的时候在load入主存(物理内存)中。这个就是内存管理所要做的事。内存管理还有另外一件事需要做:计算程序片段在主存中的物理位置,以便CPU调度。内存管理有块式管理,页式管理,段式和段页式管理。现在常用段页式管理块式管理:把主存分为一大块、一大块的,当所需的程序片断不在主存时就分配一块主存空间,把程 序片断load入主存,就算所需的程序片度只有几个字节也只能把这一块分配给它。这样会造成很大的浪费,平均浪费了50的内存空间,但时易于管理。页式管理:把主存分为一页一页的,每一页的空间要比一块一块的空间小很多,显然这种方法的空间利用率要比块

4、式管理高很多。段式管理:把主存分为一段一段的,每一段的空间又要比一页一页的空间小很多,这种方法在空间利用率上又比页式管理高很多,但是也有另外一个缺点。一个程序片断可能会被分为几十段,这样很多时间就会被浪费在计算每一段的物理地址上(计算机最耗时间的大家都知道是I/O吧)。段页式管理:结合了段式管理和页式管理的优点。把主存分为若干页,每一页又分为若干段。好处就很明显,不用我多说了吧。各种内存管理都有它自己的方法来计算出程序片断在主存中的物理地址,其实都很相似。这只是一个大概而已,不足以说明内存管理的皮毛。无论哪一本操作系统书上都有详细的讲解-4.#include stdafx.h#define S

5、QR(X) X*Xint main(int argc, char* argv)int a = 10;int k = 2;int m = 1;a /= SQR(k+m)/SQR(k+m); printf(%dn,a); return 0;这道题目的结果是什么啊?define 只是定义而已,在编择时只是简单代换X*X而已,并不经过算术法则的-5.const 符号常量;(1)const char *p(2)char const *p(3)char * const p说明上面三种描述的区别;如果const位于星号的左侧,则const就是用来修饰指针所指向的变量,即指针指向为常量;如果const位于星号

6、的右侧,const就是修饰指针本身,即指针本身是常量。(1)const char *p一个指向char类型的const对象指针,p不是常量,我们可以修改p的值,使其指向不同的char,但是不能改变它指向非char对象,如:const char *p;char c1=a;char c2=b;p=&c1;/okp=&c2;/ok*p=c1;/error(3)char * const p此时*p可以修改,而p不能修改。(4)const char * const p这种是地址及指向对象都不能修改。-6.下面是C语言中两种if语句判断方式。请问哪种写法更好?为什么?int n;if (n = 10) /

7、 第一种判断方式if (10 = n) / 第二种判断方式第二种好如果少了个=号,编译时就会报错,减少了出错的可能行,可以检测出是否少了=-7.下面的代码有什么问题?void DoSomeThing(.)char* p;.p =(char *) malloc(1024); / 分配1K的空间if (NULL = p)return;.p = realloc(p, 2048); / 空间不够,重新分配到2Kif (NULL = p)return;.A:p = malloc(1024); 应该写成: p = (char *) malloc(1024); 没有释放p的空间,造成内存泄漏。-8.下面的代

8、码有什么问题?并请给出正确的写法。void DoSomeThing(char* p)char str16;int n;assert(NULL != p);sscanf(p, %s%d, str, &n);if (0 = strcmp(str, something).A:sscanf(p, %s%d, str, n); 这句该写成: sscanf(p, %s%d, str, &n);-9.下面代码有什么错误?Void test1() char string10; char *str1=0123456789;strcpy(string, str1); 数组越界-10.下面代码有什么问题?Void

9、test2() char string10, str110; for(i=0; i10;i+) str1i =a; strcpy(string, str1); 数组越界-11.下面代码有什么问题?Void test3(char* str1) char string10; if(strlen(str1)=10) strcpy(string, str1); =数组越界=strcpy拷贝的结束标志是查找字符串中的0 因此如果字符串中没有遇到0的话 会一直复制,直到遇到0,上面的123都因此产生越界的情况建议使用 strncpy 和 memcpy-12.下面代码有什么问题?#define MAX_SR

10、M 256 DSN get_SRM_no() static int SRM_no; /是不是这里没赋初值?int I; for(I=0;I=MAX_SRM) return (NULL_SRM); else return SRM_no; 系统会初始化static int变量为0,但该值会一直保存,所谓的不可重入.-13.写出运行结果:/ test1 char str = world; cout sizeof(str) : ; char *p = str; cout sizeof(p) : ; char i = 10; cout sizeof(i) : ; void *pp = malloc(10

11、); cout sizeof(p) endl;6:4:1:4-14.写出运行结果:/ test2 union V struct X unsigned char s1:2; unsigned char s2:3; unsigned char s3:3; x;unsigned char c; v; v.c = 100; printf(%d, v.x.s3); 3-15.用C+写个程序,如何判断一个操作系统是16位还是32位的?不能用sizeof()函数A1:16位的系统下,int i = 65536;cout i; / 输出0;int i = 65535;cout i; / 输出-1;32位的系统

12、下,int i = 65536;cout i; / 输出65536;int i = 65535;cout 65536 ) cout32 bitendl;else cout16 bitendl;-16.C和C+有什么不同?从机制上:c是面向过程的(但c也可以编写面向对象的程序);c+是面向对象的,提供了类。但是,c+编写面向对象的程序比c容易从适用的方向:c适合要求代码体积小的,效率高的场合,如嵌入式;c+适合更上层的,复杂的; llinux核心大部分是c写的,因为它是系统软件,效率要求极高。从名称上也可以看出,c+比c多了+,说明c+是c的超集;那为什么不叫c+而叫c+呢,是因为c+比c来说扩

13、充的东西太多了,所以就在c后面放上两个+;于是就成了c+C语言是结构化编程语言,C+是面向对象编程语言。C+侧重于对象而不是过程,侧重于类的设计而不是逻辑的设计。-17.在不用第三方参数的情况下,交换两个参数的值#include void main() int i=60; int j=50; i=i+j; j=i-j; i=i-j; printf(i=%dn,i); printf(j=%dn,j);方法二:i=j;j=i;i=j;方法三:/ 用加减实现,而且不会溢出a = a+b-(b=a)-18.有关位域的面试题(为什么输出的是一个奇怪的字符)a.t = b;效果相当于 a.t= b & 0

14、xf;b - 01100010b & 0xf -00000010所以输出Ascii码为2的特殊字符char t:4;就是4bit的字符变量,同样unsigned short i:8;就是8bit的无符号短整形变量-19.int i=10, j=10, k=3; k*=i+j; k最后的值是?60-20.进程间通信的方式有?进程间通信的方式有 共享内存, 管道 ,Socket ,消息队列 , DDE等信号,信号量,消息队列,共享内存,-21.struct A char t:4; char k:4; unsigned short i:8; unsigned long m; sizeof(A)=?(

15、不考虑边界对齐)7struct CELL / Declare CELL bit field unsigned character : 8; / 00000000 ? unsigned foreground : 3; / 00000? 00000000 unsigned intensity : 1; / 0000?000 00000000 unsigned background : 3; / 0?0000 00000000 unsigned blink : 1; / ?0000000 00000000 screen2580; / Array of bit fields二、位结构 位结构是一种特殊

16、的结构, 在需按位访问一个字节或字的多个位时, 位结构 比按位运算符更加方便。 位结构定义的一般形式为: struct位结构名 数据类型 变量名: 整型常数; 数据类型 变量名: 整型常数; 位结构变量; 其中: 数据类型必须是int(unsigned或signed)。 整型常数必须是非负的整 数, 范围是015, 表示二进制位的个数, 即表示有多少位。 变量名是选择项, 例如: 下面定义了一个位结构。可以不命名, 这样规定是为了排列需要。 struct unsigned incon: 8; /*incon占用低字节的07共8位*/ unsigned txcolor: 4;/*txcolor占

17、用高字节的03位共4位*/ unsigned bgcolor: 3;/*bgcolor占用高字节的46位共3位*/ unsigned blink: 1; /*blink占用高字节的第7位*/ ch; 位结构成员的访问与结构成员的访问相同。 例如: 访问上例位结构中的bgcolor成员可写成: ch.bgcolor 注意: 1. 位结构中的成员可以定义为unsigned, 也可定义为signed, 但当成员长 度为1时, 会被认为是unsigned类型。因为单个位不可能具有符号。 2. 位结构中的成员不能使用数组和指针, 但位结构变量可以是数组和指针, 如果是指针, 其成员访问方式同结构指针。

18、3. 位结构总长度(位数), 是各个位成员定义的位数之和, 可以超过两个字 节。 4. 位结构成员可以与其它结构成员一起使用。 例如: struct info char name8; int age; struct addr address; float pay; unsigned state: 1; unsigned pay: 1; workers; 上例的结构定义了关于一个工人的信息。其中有两个位结构成员, 每个位结 构成员只有一位, 因此只占一个字节但保存了两个信息, 该字节中第一位表示工 人的状态, 第二位表示工资是否已发放。由此可见使用位结构可以节省存贮空间。-22.下面的函数实现在

19、一个固定的数上加上一个数,有什么错误,改正 int add_n(int n) static int i=100; i+=n; return i; 答:因为static使得i的值会保留上次的值。去掉static就可了-23.下面的代码有什么问题?class A public: A() p=this; A() if(p!=NULL) delete p; p=NULL; A* p; ;答:会引起无限递归-24.union a int a_int1;double a_double;int a_int2;typedef structa a1;char y; b;class cdouble c_doubl

20、e;b b1;a a2;输出coutsizeof(c)j+) & (i+ = j) i+=j;答:i = 5-26.unsigned short array=1,2,3,4,5,6,7;int i = 3;*(array + i) = ?答:4-27.class Avirtual void func1();void func2();Class B: class Avoid func1()cout fun1 in class B endl;virtual void func2()cout fun2 in class B endl; A, A中的func1和B中的func2都是虚函数.B, A中的func1和B中的func2都不是虚函数.C, A中的func2是虚函数.,B中的func1不是虚函数.D, A中的func2不是虚函数,B中的func1是虚函数.答:A-28.数据库:抽出部门,平均工资,要求按部门的字符串

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1