摘要: 1、堆和栈的区别?答:1、栈区(stack)— 由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。 2、堆区(heap) 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收 。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表,呵呵。 3、栈是向下增长的,堆是向上增长的。(可以参考上一篇博客)下面是一个例子程序:view plain//main.cppinta=0;//全局初始化区char*p1;//全局未初始化区voidmain(){intb;//栈chars[]="abc";//栈char*p2;//栈char* 阅读全文
posted @ 2011-10-23 15:05 张兰云 阅读(480) 评论(0) 推荐(0) 编辑
摘要: 1、下面的排序算法中,初始数据集的排列顺序对算法的性能无影响的是(B)A、插入排序B、堆排序 C、冒泡排序 D、快速排序2、以下关于Cache的叙述中,正确的是(B)A、CPU中的Cache容量应大于CPU之外的Cache容量B、Cache的设计思想是在合理成本下提高命中率C、Cache的设计目标是容量尽可能与主存容量相等D、在容量确定的情况下,替换算法的时间复杂度是影响Cache命中率的关键因素3、数据存储在磁盘上的排列方式会影响I/O服务的性能,一个圆环的磁道上有10个物理块,10个数据记录R1------R10存放在这个磁道上,记录的安排顺序如下表所示:物理块12345678910逻辑记 阅读全文
posted @ 2011-10-23 15:02 张兰云 阅读(541) 评论(0) 推荐(1) 编辑