传闻公司老总欠下巨款,带着小姨子跑路了~  树倒猢狲散,接下来要好好准备面试,以期找到一份满意的工作。

面试准备分下面几个方面进行,形成面试系列文章,文章内容以问答的方式呈现。

1.C++语言基础

传统C++:

虚函数必知必问(父子类构造析构顺序、父类析构函数应该声明为virtual吗) 、多重继承类成员在空间中的分布、四类转型操作符(reinterpret_cast等)使用场景、static关键字的作用、虚函数表的布局(菱形继承的缺点以及每个对象的空间分布)

现代C++:

auto关键字、左值与右值、移动语义与完美转发、for-each循环、智能指针(std::shared_ptr、std::unique_ptr实现细节)、RAII概念、STL容器的emplace_back、线程库std::thread+std::mutex+std::conditon_variable+std::lock_forward、lambda捕获、std::bind+std::function等(待补充)

2.算法与数据结构基础

1)排序(快速排序>冒泡排序>归并排序>桶排序),给出实现原理,分析算法复杂度、最好最坏情况下的复杂度。

2)二分查找使用场景

3)链表的创建、插入、删除、查找、翻转、连接,算法需尽量写出来,注意边界检查、空指针、函数返回链表头部指针以建立引用等

4)队列与栈

队列涉及消费者-生产者模型、多线程同步等

栈的问题通常结合函数调用展开。比如printf函数为什么不能声明为 stdcall方式

5)哈希表(问的比较多)

哈希冲突的检测、哈希插入函数实现、

6)树

红黑树 概念 左旋右旋的方式、分析查找和插入时的平均算法复杂度、最好最坏时的算法复杂度,涉及STL中的MAP

B树问的较少,变形问题:MySQL 索引实现原理

7)其他的一些算法

A*寻路,霍夫曼编码等

3.编码基本功

编程素养如编码风格、计算机英语水平、调试能力等(调试能力是大牛必备)

基础编码题如实现memmove、strcopy、atoi等

4.多线程开发基础

知道何时新建线程、如何创建和等待线程、线程与进程的关系、线程局部存储、多线程竞态的产生和避免(死锁处理)

熟悉日常开发平台所属操作系统的线程同步原语(CriticalSection、Event、Mutex、Sempored、WaitForSingleObject、WaitForMultipleObject)

5.数据库

①传统关系型数据库

1)基本sql操作如增删改查(Insert、delete、update、select)、排序(order)、条件查询(where子句)、限制查询结果数量(limit语句)

2)  高级点的sql操作如(Group by,in,join,left join,多表联合查询,别名使用,select子语句等)

3)数据库本身的操作,建库建表、数据的导入导出

4)SQL优化技巧(非重点)

②内存数据库(redis):

这么说吧,熟悉redis是后台开发的基本要求了。

1)基础用法:redis的基础数据类型、数据持久化、事务等

2)redis源码层面:redis的网络通信模型、redis各种数据结构的实现

redis本身就是一个非常值得学习的开源代码库

6.网络编程

select函数用法、非阻塞connect函数写法、阻塞socket与非阻塞socket区别、send/recv函数的返回值情形、reuse_addr选项等。Windows平台上的WSAEventSelect、

WSAAsyncSelect函数用法、完成端口(IOCP)模型。

更深入的一些知识点有:

1)nagle算法

2)keeplive选项

3)Linger选项(在http中send完后是否立即close socket)

4)处理大量CLOSE_WAIT或TIME_WAIT

5)通讯协议如何设计或如何解决数据包的粘包与分片问题

6)心跳机制如何设计(如何检查死链)

7)断线重连机制如何设计

8)对IO Multiplexing技术的理解

9)如何正确收发数据包,收发缓冲区如何设计

10)优雅关闭

11)定时器如何设计

12)流量拥塞与控制机制

13)tcp与udp的区别与适用场景

14)http中的GET/POST区别

7.项目经验总结

项目整体的架构图、负责处理的模块、解决过什么难以排查的bug等等

剑指C++面试的更多相关文章

  1. 慕课网:剑指Java面试-Offer直通车视频课程

    慕课网:剑指Java面试-Offer直通车视频课程,一共有10个章节. 目录结构如下: 目录:/2020036-慕课网:剑指Java面试-Offer直通车 [6G] ┣━━第10章 Java常用类库与 ...

  2. 剑指offer 面试5题

    面试5题: 题目:请实现一个函数,将一个字符串中的空格替换成“%20”.例如,当字符串为We Are Happy.则经过替换之后的字符串为We%20Are%20Happy. 方法一: # -*- co ...

  3. 剑指offer 面试8题

    面试8题: 题目:二叉树的下一个节点 题目描述:给定一个二叉树和其中的一个结点,请找出中序遍历顺序的下一个结点并且返回.注意,树中的结点不仅包含左右子结点,同时包含指向父结点的指针. 解题思路:详见剑 ...

  4. 剑指offer 面试10题

    面试10题: 题目:大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项.n<=39 n=0时,f(n)=0 n=1时,f(n)=1 n>1时,f(n)=f(n-1 ...

  5. 剑指offer 面试11题

    面试11题: 题目: 把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转. 输入一个非递减排序的数组的一个旋转,输出旋转数组的最小元素. 例如数组{3,4,5,1,2}为{1,2,3,4 ...

  6. 剑指offer 面试14题

    面试14题: 题目:剪绳子 题:给你一根长度为n的绳子,请把绳子剪成m段(m,n都是整数,且n>1,m>1),每段绳子的长度记为k[0],k[1],k[2],...,k[m].请问k[0] ...

  7. 剑指offer 面试17题

    面试17题: 题目:打印从1到最大的n位数 题:输入数字n,按顺序打印出从1到最大的n位十进制数,比如输入3,则打印出1.2.3一直到最大的3位数999. 解题思路:需要考虑大数问题,这是题目设置的陷 ...

  8. 剑指offer 面试26题

    面试26题: 题目:树的子结构 题:输入两棵二叉树A和B,判断B是不是A的子结构. 解题思路:递归,注意空指针的情况. 解题代码: # -*- coding:utf-8 -*- # class Tre ...

  9. 剑指offer 面试29题

    面试29题: 题目:顺时针打印矩阵(同LeetCode 螺旋矩阵打印) 题:输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 1 2 3 4 5 6 7 8 9 ...

  10. 剑指offer 面试32题

    面试32题: 题目:从上到下打印二叉树 题:不分行从上到下打印二叉树 解题代码: # -*- coding:utf-8 -*- # class TreeNode: # def __init__(sel ...

随机推荐

  1. windows server 2012R2 故障转移集群配置

    配置说明: AD:10.10.1.10/24  Node-2:10.10.1.20/24 Node-3:10.10.1.30/24 zhangsan-PC:10.10.1.50/24  VIP1:10 ...

  2. TZOJ 2289 Help Bob(状压DP)

    描述 Bob loves Pizza but is always out of money. One day he reads in the newspapers that his favorite ...

  3. java 坑总结

    1.Cannot find current proxy: Set 'exposeProxy' property on Advised to 'true' to make it available. 解 ...

  4. python requests库爬取网页小实例:ip地址查询

    ip地址查询的全代码: 智力使用ip183网站进行ip地址归属地的查询,我们在查询的过程是通过构造url进行查询的,将要查询的ip地址以参数的形式添加在ip183url后面即可. #ip地址查询的全代 ...

  5. Linux 学习笔记 4:Shell 编程

    1.简单过滤器 a. pr [OPTION] [FILE] 功能:改变文件打印格式 选项 功能 -l n 设定页面长度为n行 -w n 设定页面总宽度为n个字符(不够会被砍掉) -h str 设定页眉 ...

  6. leetcode4:两个排序数组的中位数

    给定两个大小为 m 和 n 的有序数组 nums1 和 nums2 . 请找出这两个有序数组的中位数.要求算法的时间复杂度为 O(log (m+n)) . 1.我的思路:直接用sort,时间复杂度应如 ...

  7. vim 中文乱码怎么解决

    一般来说只需要正确设置vim的编码识别序列就很少会遇到乱码问题: set fileencodings=ucs-bom,utf-8,utf-16,gbk,big5,gb18030,latin1 这个设置 ...

  8. Vs2017的git真S B

    1.先是无法克隆 2.修改用户还是无法克隆 3.修改用户凭据还是无法克隆 4.重装机器,将vs改为2017企业版,他妈的还是无法克隆 5.测试发现我这台机子无法克隆,其他的可以 6.提示永远是 Git ...

  9. 树莓派3 开机自启动(SPI)

    转自:https://www.raspberrypi-spy.co.uk/2014/08/enabling-the-spi-interface-on-the-raspberry-pi/ 方案一:图形界 ...

  10. @无痕客 https://www.cnblogs.com/wuhenke/archive/2012/12/24/2830530.html 通篇引用

    无痕客 https://www.cnblogs.com/wuhenke/archive/2012/12/24/2830530.html 关于Async与Await的FAQ 关于Async与Await的 ...