C++笔试易错题集(持续更新)
1.如下代码输出结果是什么?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
#include<stdio.h> char *myString() { char buffer[ 6 ] = { 0 }; char *s = "Hello World!" ; for ( int i = 0 ; i < sizeof(buffer) - 1 ; i++) { buffer[i] = *(s + i); } return buffer; } int main( int argc, char **argv) { printf( "%s\n" , myString()); return 0 ; } |
- Hello
- Hello World!
- Well
- 以上全部不正确
解析:
答案:D
函数char *myString()中没有使用new或者malloc分配内存,所有buffer数组的内存区域在栈区
随着char *myString()的结束,栈区内存释放,字符数组也就不存在了,所以会产生野指针,输出结果未知
2.
1
2
3
4
5
6
7
|
enum string{ x1, x2, x3= 10 , x4, x5, } x; |
1
2
3
4
5
6
7
8
|
C c; void main() { A*pa= new A(); B b; static D d; delete pa; }
|
这道题主要考察的知识点是 :全局变量,静态局部变量,局部变量空间的堆分配和栈分配
其中全局变量和静态局部变量时从 静态存储区中划分的空间,
二者的区别在于作用域的不同,全局变量作用域大于静态局部变量(只用于声明它的函数中),
而之所以是先释放 D 在释放 C的原因是, 程序中首先调用的是 C的构造函数,然后调用的是 D 的构造函数,析构函数的调用与构造函数的调用顺序刚好相反。
局部变量A 是通过 new 从系统的堆空间中分配的,程序运行结束之后,系统是不会自动回收分配给它的空间的,需要程序员手动调用 delete 来释放。
局部变量 B 对象的空间来自于系统的栈空间,在该方法执行结束就会由系统自动通过调用析构方法将其空间释放。
之所以是 先 A 后 B 是因为,B 是在函数执行到 结尾 "}" 的时候才调用析构函数, 而语句 delete a ; 位于函数结尾 "}" 之前。
1
2
3
4
5
6
7
8
9
10
11
12
13
|
class CTest { public : CTest():m_chData(‘\0’),m_nData(0) { } virtual void mem_fun(){} private : char m_chData; int m_nData; static char s_chData; }; char CTest::s_chData=’\0’; |
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
#include<iostream> using namespace std; class MyClass { public : MyClass( int i = 0 ) { cout << i; } MyClass( const MyClass &x) { cout << 2 ; } MyClass &operator=( const MyClass &x) { cout << 3 ; return * this ; } ~MyClass() { cout << 4 ; } }; int main() { MyClass obj1( 1 ), obj2( 2 ); MyClass obj3 = obj1; return 0 ; } |
运行时的输出结果是()
- 11214444
- 11314444
- 122444(正确)
- 123444
解析:首先程序中存在三个MyClass对象。
前两个对象构造时分别输出1,2
第三个对象是这样构造的MyClass obj3 = obj1;这里会调用拷贝构造函数,输出2
然后三个对象依次析构,输出444
所以最终输出122444 MyClass obj3 = obj1;这里调用拷贝构造函数,
如果是在这之前obj3,obj1都已声明,则此时调用的是coby assignment操作符
1
2
3
4
5
6
|
int add( int *x, int *y, int *z){ *x += *x; *y += *x; *z += *y; return *z; } |
- 4
- 5
- 6
- 7
- 数据查询
- 数据控制
- 数据定义
- 数据操纵
8.观察下面一段代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
|
class ClassA { public: virtual ~ ClassA(){}; virtual void FunctionA(){}; }; class ClassB { public: virtual void FunctionB(){}; }; class ClassC : public ClassA,public ClassB { public: }; ClassC aObject; ClassA* pA=&aObject; ClassB* pB=&aObject; ClassC* pC=&aObject; |
关于pA,pB,pC的取值,下面的描述中正确的是:
- pA,pB,pC的取值相同.
- pC=pA+pB
- pA和pB不相同
- pC不等于pA也不等于pB
0x7fff502f5aa80x7fff502f5ab00x7fff502f5aa8
- 3
- 4
- 5
- 8
- 2040
- 2042
- 2045
- 2050
第1500个数是:1500/22=68 1500%68=4。也就是说:第1500个数相当于经过了68个周期,然后再取下一个周期内的第4个数。一个周期内的前4个数:2,3,4,5。
故,结果为68*30=2040+5=2045
- (AB)C
- A(BC)
- (AC)B
- (BC)A
- (CA)B
- 忽略测量和计算误差,可以转换为(0,1)区间上的均匀分布
- 无法转换为(0,1)区间上的均匀分布
- 信息不足,无法判断
- 借助伪随机数生成算法可以转换为(0,1)区间上的均匀分布
- 仅仅靠伪随机数生成算法,就可以生成(0,1)区间上的均匀分布
- 以上说法都不对
- O(n)
- O(n log n)
- O(n^2)
- O(n^3)
- O(logn)
- 不确定
解析:最坏的情况就是这个二分查找树的所有节点只有左子树或者只有右子树,就相当于一个线性链表,所以是O(n)
- int i=0;i=(i++);
- char *p=”hello”;p[1]=’E’
- char *p=”hello”;char ch=*p++
- int i=0;printf(“%d%d\n”,i++ i--)
- 都是未定义行为
- 都不是未定义行为
解析:C
- 对于栈来讲,生长方向是向上的,也就是向着内存地址增加的方向
- 对于堆,大量的 new/delete 操作会造成内存空间的不连续
- 堆容易产生 memory leak D,堆的效率比栈要低的多
- 堆的效率比栈要低得多
- 栈变量引用容易逃逸
- 以上都对
解析:堆的生长方向向上,栈的生长方向向下17.在小端序的机器中,如果
1
2
3
4
|
union X{ int x; char y[4]; }; |
如果:
X a;
a.x=0x11223344;//16 进制 则:______
- a.y[0]=11
- a.y[1]=11
- a.y[2]=11
- a.y[3]=11
- a.y[0]=22
- a.y[3]=22
解析:小端是数据低字节存储在内存低位,所以y[0]=0x44,y[3] = 0x1118.下面的排序算法中,初始数据集的排列顺序对算法的性能无影响的是
- 插入排序
- 堆排序
- 冒泡排序
- 快速排序
解析:
- 运行→就绪
- 运行→等待
- 等待→运行
- 等待→就绪
解析:选C ,就绪状态是可以和运行状态相互转换的,超时的时候就会从运行状态转为就绪状态。但是一旦是等待状态(阻塞)就必须选转为就绪才能够运行。
- 会有内存泄露
- 不会有内存泄露,但不建议用
- 编译就会报错,必须使用delete []p;
- 编译没问题,运行会直接崩溃
解析:the answer is B , if the type is int,char,float, both delete[]p and delete p are ok,but if the type is class object, the answer will be A
21.x为整型,请用位运算实现x%8解析:
C++笔试易错题集(持续更新)的更多相关文章
- C语言常见易错题集(分析及解答)(仅可用于交流,勿用于商业用途)
1.能正确表示a和b同时为正或同时为负的逻辑表达式是( D ). A.(a>=0||b>=0)&&(a<0||b<0) B.(a> ...
- DataStage 错误集(持续更新)
DataStage 错误集(持续更新) DataStage序列文章 DataStage 一.安装 DataStage 二.InfoSphere Information Server进程的启动和停止 D ...
- Bug是一种财富-------研发同学的错题集、测试同学的遗漏用例集
此文已由作者王晓明授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 各位看官,可能看到标题的你一定认为这是一篇涉嫌"炒作"的文章,亦或是为了吸引眼球而起的标 ...
- 知道创宇爬虫题--代码持续更新中 - littlethunder的专栏 - 博客频道 - CSDN.NET
知道创宇爬虫题--代码持续更新中 - littlethunder的专栏 - 博客频道 - CSDN.NET undefined 公司介绍 - 数人科技 undefined
- S2 深入.NET和C#编程 笔试测试错题积累
---恢复内容开始--- <深入.NET平台和C#编程>内部测试题-笔试试卷错题积累 1: 1) 以下关于序列化和反序列化的描述错误的是( C). a) 序列化是将对象的状态存储到特定存储 ...
- 【笔试题】Java 易错题精选
笔试题 Java 易错题精选 1.写出下列程序的运行结果( )String 不变性Java 值传递 public class Test { public static void main(String ...
- Java五道输出易错题解析(避免小错误)
收集了几个易错的或好玩的Java输出题,分享给大家,以后在编程学习中稍微注意下就OK了. 1. 看不见的空格? 下面的输出会正常吗? package basic; public class Integ ...
- Java五道输出易错题解析(进来挑战下)
转自:http://blog.csdn.net/lanxuezaipiao/article/details/41985243 收集了几个易错的或好玩的Java输出题,分享给大家,以后在编程学习中稍微注 ...
- 杭电OJ2039——三角形(c++)(易错题:数据类型不确定)
三角形 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submis ...
随机推荐
- 2-Eighteenth Scrum Meeting-20151218
任务安排 成员 今日完成 明日任务 闫昊 写完学习进度记录的数据库操作 写完学习进度记录的数据库操作 唐彬 编写与服务器交互的代码 和服务器老师交流讨论区后台接口 史烨轩 获取视频url 尝试使用 ...
- [2017BUAA软工助教]个人得分总表(至alpha结束)
一.表 学号 第0次 week1 week2 week3 个人项目 附加1 结对项目 附加2 a团队 a团队得分 a贡献分 总分(不计) 总分(记) 15061119 7 9.5 12 9 45.75 ...
- 老李的blog使用日记(2)
寥寥数语结束一个不曾期待的遇见,可还是剧情不会这样结束,他也会在我的时间里注册自己的专属账号,无论什么时候,他会时而需要被注视着,为了达到目的,即使不择手段,只为一次擦肩而过的邂逅,极短的一段时间,相 ...
- Apache DBUtils框架 结果处理器
package com.itheima.dbutil; import java.util.List; import java.util.Map; import org.apache.commons.d ...
- WebView 5.0+闪烁以及白屏问题完美解决
Android webView 在5.0+上启动硬件加速,造成部分手机出现闪烁.白屏等现象 必须写下这篇博客,遇到的问题搞了很久,百度谷歌就是没有完整的答案,记录下来,方便博友们: 需求:一个简单的W ...
- 对象内存空间 在创建对象后 运行时 会把对象的方法放到jvm的方法区中 调用时 将方法拿到栈中 执行完后 这个方法会出栈 然后新的方法方法进栈
- Reachability from the Capital CodeForces - 999E(强连通分量 缩点 入度为0的点)
题意: 问至少加几条边 能使点s可以到达所有的点 解析: 无向图的连通分量意义就是 在这个连通分量里 没两个点之间至少有一条可以相互到达的路径 所以 我们符合这种关系的点放在一起, 由s向这些点的任 ...
- 洛谷 P5162 WD与积木 解题报告
P5162 WD与积木 题目背景 WD整日沉浸在积木中,无法自拔-- 题目描述 WD想买\(n\)块积木,商场中每块积木的高度都是\(1\),俯视图为正方形(边长不一定相同).由于一些特殊原因,商家会 ...
- Codechef Sad Pairs——圆方树+虚树+树上差分
SADPAIRS 删点不连通,点双,圆方树 非割点:没有影响 割点:子树DP一下 有不同颜色,所以建立虚树 在圆方树上dfs时候 如果当前点是割点 1.统计当前颜色虚树上的不连通点对,树形DP即可 2 ...
- 【java】JDK、JRE、JVM的关系
目录结构: contents structure [-] 什么是JDK,JRE,JVM 安装JDK的时候为什么有两个jre 专用JRE 共用JRE 共用JRE和专用JRE的对比 java的跨平台特性 ...