C++与操作系统笔试题:析构、内存、进程通讯与数据库索引

需积分: 9 0 下载量 193 浏览量 更新于2024-09-07 收藏 23KB DOCX 举报
"腾讯2017年针对校园招聘的开发工程师笔试题目,涉及C++、Linux、数据库和操作系统方面的知识。" 这部分内容主要考察了考生对于C++对象生命周期、类继承、内存管理以及Linux进程间通信、数据库索引和操作系统中死锁的理解。 首先,C++部分的问题涉及类的构造与析构。在32位环境下,给定的代码会输出"AABB~B~A"。这是因为在创建`B`类型的指针`c`时,会先调用基类`A`的构造函数,然后是派生类`B`的构造函数,因此输出`AB`。当使用`delete[] c`删除动态分配的数组时,会先调用派生类`B`的析构函数,然后是基类`A`的析构函数,所以输出`~B~A`。选项c是正确答案。 接着是C++类大小的问题。一个空类`CTest`在32位机器上的大小: - a. 不正确,即使是空类,编译器也会为其分配至少1个字节的空间,以便于区别不同对象。 - b. 正确,如果添加了构造函数,编译器需要存储函数指针,通常会使得类大小增加1个字节。 - c. 正确,添加虚函数会引入虚表指针,通常在32位系统上占4个字节。 - d. 不正确,添加虚函数后的大小是4个字节,不是5个。 在Linux进程间通信方面,提供了以下几种方式: - a. UNIX套接字:允许在同一台机器上的进程之间通信。 - b. 信号量:用于同步进程间的访问,防止资源竞争。 - c. 无名管道:简单且直接的进程间通信方式,但只适用于父子进程或兄弟进程。 - d. 文件锁:可以用来保护文件资源,防止多个进程同时修改。 - e. 共享内存:多个进程可以直接读写同一块内存区域,高效但需要额外的同步机制。 数据库唯一索引的问题: - a. 正确,一个表可以有多个唯一约束,但主键必须唯一且不允许为空。 - b. 不正确,唯一约束列不允许有重复值,但可以包含NULL。 - c. 正确,唯一约束列的值可以被修改或更新,只要新的值也是唯一的。 - d. 错误,因为选项a和c是正确的。 最后是关于死锁的描述: - a. 正确,通过预先确定资源的分配顺序,可以避免循环等待条件,从而预防死锁。 - b. 错误,银行家算法是一种用于避免死锁的策略,而不是检测死锁。 - c. 错误,剥夺所有资源可能会导致其他进程无法继续执行,不是解决死锁的常用方法。 - d. 错误,因为选项a是正确的描述。 另外,还有一个C++代码片段,指出其中的错误。这段代码存在4处错误: 1. `classB1`的构造函数声明中多了一个括号。 2. `B1()`构造函数中,`_s`应当用`new char[1024]`初始化,而不是`newchar[1024]`。 3. `voidf()`在`B1`中应该是私有的,但在声明中没有指定访问修饰符。 4. 类`B2`的`virtual void f()`后面缺少分号。 这些题目覆盖了C++基础、面向对象特性、操作系统原理以及数据库管理等多个IT核心领域的知识。