写在之前:本人是算法转开发,看客户端无基础无经验就投递了字节客户端开发,这次面试面试官全程黑脸,体验极差,我好菜啊
问的问题及本人回答以及面试官评价如下:
1、设计一个聊天客户端
我:我没有客户端开发经验
面试官:(摇头)
2、进程拥有的资源
答:
- 虚拟地址空间
- 一个全局唯一的进程ID (PID)
- 一个可执行映像(image),也就是该进程的程序文件在内存中的表示
- 一个或多个线程
- 一个位于内核空间中的名为EPROCESS(executive process block,进程执行块)的数据结构,用以记录该进程的关键信息,包括进程的创建时间、映像文件名称等。
- 一个位于内核空间中的对象句柄表,用以记录和索引该进程所创建/打开的内核对象。操作系统根据该表格将用户模式下的句柄翻译为指向内核对象的指针。
- 一个位于描述内存目录表起始位置的基地址,简称页目录基地址(DirBase),当CPU切换到该进程/任务时,会将该地址加载到CR3寄存器,这样当前进程的虚拟地址才会被翻译为正确的物理地址。
- 一个位于用户空间中的进程环境块(Process Environment Block, PEB)。
- 一个访问权限令牌(access token),用于表示该进程的用户、安全组,以及优先级别。
面试官:(摇头)
3、操作系统如何实现系统调用
答:在硬件设计上,通过区分内核态和用户态来把内核程序和用户程序隔离开,CS寄存器最低的两位为0即是内核态,为3是用户态
但是系统调用的代码是处在内核态的,所以就需要提供一种方法来能够让用户程序进入内核态来实现系统调用
在X86里,INT指令就是硬件用来提供由用户态进入内核态的方法,所以系统调用的实现就可以变为:
- 由用户程序发起一个INT指令,指明要调用的服务
- 在操作系统里写出相应的中断处理
- 由操作系统根据用户指明要调用的服务取执行相应的代码
面试官:(不对)
答:我不清楚了
4、C++异常机制
C++ 通过 throw 语句和 try...catch 语句实现对异常的处理。throw 语句的语法如下:
try...catch 语句的语法如下:
把 try 和其后{}中的内容称作“try块”,把 catch 和其后{}中的内容称作“catch块”。
try...catch 语句的执行过程是:
throw 表达式;
try...catch 语句的语法如下:
try { 语句组 } catch(异常类型) { 异常处理代码 } ... catch(异常类型) { 异常处理代码 }
把 try 和其后{}中的内容称作“try块”,把 catch 和其后{}中的内容称作“catch块”。
try...catch 语句的执行过程是:
- 执行 try 块中的语句,如果执行的过程中没有异常拋出,那么执行完后就执行最后一个 catch 块后面的语句,所有 catch 块中的语句都不会被执行;
- 如果 try 块执行的过程中拋出了异常,那么拋出异常后立即跳转到第一个“异常类型”和拋出的异常类型匹配的 catch 块中执行(称作异常被该 catch 块“捕获”),执行完后再跳转到最后一个 catch 块后面继续执行。
5、多态机制
答:多态分为静态多态和动态多态
静态多态是在编译期间完成,根据函数参数实参判断需要调用的函数。以此形成了函数重载技术和泛型编程。
动态多态则是利用虚函数实现了运行时的多态,也就是说在系统编译的时候并不知道程序将要调用哪一个函数,只有在运行到这里的时候才能确定接下来会跳转到哪一个函数的栈帧。
面试官:不对,底层实现
我:虚函数、虚函数表、虚指针~巴拉巴拉
面试官:摇头+叹气
我:函数重载、重写~巴拉巴拉
面试官:沉默
6、代码:
宏定义返回较大值
函数指针做形参,返回int
一条直线线段覆盖
面试还没结束,短信说已挂,我好菜啊
发帖给接下来面的同学一点准备,避免遇到手忙脚乱,我被面试劝退,祝大家顺利~
全部评论
(25) 回帖