前段时间专心面过腾讯,通过了N轮的技术面,结果仍是挂了,但没挂在技术面,比较欣慰,回来以后写一点总结,以供有梦想进入腾讯作后台服务器开发的同窗参考,本文章为胡成精心总结,胡成原创,copy和转载请通知。ps:()以内的文字由做者点评,非面试题文字。mysql
linux和os:linux
netstat tcpdump ipcs ipcrm (若是这四个命令没据说过或者不能熟练使用,基本上能够回家,经过的几率较小 ^_^ ,这四个命令的熟练掌握程度基本上能体现面试者实际开发和调试程序的经验)c++
cpu 内存 硬盘 等等与系统性能调试相关的命令必须熟练掌握,设置修改权限 tcp网络状态查看 各进程状态 抓包相关等相关命令 必须熟练掌握面试
awk sed需掌握算法
共享内存的使用实现原理(必考必问,而后共享内存段被映射进进程空间以后,存在于进程空间的什么位置?共享内存段最大限制是多少?)sql
c++进程内存空间分布(注意各部分的内存地址谁高谁低,注意栈从高道低分配,堆从低到高分配)数据库
ELF是什么?其大小与程序中全局变量的是否初始化有什么关系(注意.bss段)编程
使用过哪些进程间通信机制,并详细说明(重点)缓存
makefile编写,虽然比较基础,可是会被问到服务器
gdb调试相关的经验,会被问到
如何定位内存泄露?
动态连接和静态连接的区别
32位系统一个进程最多多少堆内存
多线程和多进程的区别(重点 面试官最最关心的一个问题,必须从cpu调度,上下文切换,数据共享,多核cup利用率,资源占用,等等各方面回答,而后有一个问题必须会被问到:哪些东西是一个线程私有的?答案中必须包含寄存器,不然悲催)
写一个c程序辨别系统是64位 or 32位
写一个c程序辨别系统是大端or小端字节序
信号:列出常见的信号,信号怎么处理?
i++是否原子操做?并解释为何???????
说出你所知道的各种linux系统的各种同步机制(重点),什么是死锁?如何避免死锁(每一个技术面试官必问)
列举说明linux系统的各种异步机制
exit() _exit()的区别?
如何实现守护进程?
linux的内存管理机制是什么?
linux的任务调度机制是什么?
标准库函数和系统调用的区别?
补充一个坑爹坑爹坑爹坑爹的问题:系统如何将一个信号通知到进程?(这一题哥没有答出来)
c语言:
宏定义和展开(必须精通)
位操做(必须精通)
指针操做和计算(必须精通)
内存分配(必须精通)
sizeof必考
各种库函数必须很是熟练的实现
哪些库函数属于高危函数,为何?(strcpy等等)
c++:
一个String类的完整实现必须很快速写出来(注意:赋值构造,operator=是关键)
虚函数的做用和实现原理(必问必考,实现原理必须很熟)
sizeof一个类求大小(注意成员变量,函数,虚函数,继承等等对大小的影响)
指针和引用的区别(通常都会问到)
多重类构造和析构的顺序
stl各容器的实现原理(必考)
extern c 是干啥的,(必须将编译器的函数名修饰的机制解答的很透彻)
volatile是干啥用的,(必须将cpu的寄存器缓存机制回答的很透彻)
static const等等的用法,(能说出越多越好)
数据结构或者算法:
《离散数学》范围内的一切问题皆由可能被深刻问到(这个最坑爹,最重要,最体现功底,最能加分,特别是各种树结构的实现和应用)
各种排序:大根堆的实现,快排(如何避免最糟糕的状态?),bitmap的运用等等
hash, 任何一个技术面试官必问(例如为何通常hashtable的桶数会取一个素数?如何有效避免hash结果值的碰撞)
网络编程:
tcp与udp的区别(必问)
udp调用connect有什么做用?
tcp链接中时序图,状态图,必须很是很是熟练
socket服务端的实现,select和epoll的区别(必问)
epoll哪些触发模式,有啥区别?(必须很是详尽的解释水平触发和边缘触发的区别,以及边缘触发在编程中要作哪些更多的确认)
大规模链接上来,并发模型怎么设计
tcp结束链接怎么握手,time_wait状态是什么,为何会有time_wait状态?哪一方会有time_wait状态,如何避免time_wait状态占用资源(必须回答的详细)
tcp头多少字节?哪些字段?(必问)
什么是滑动窗口(必问)
connect会阻塞,怎么解决?(必考必问,提示:设置非阻塞,返回以后用select检测状态)
若是select返回可读,结果只读到0字节,什么状况?
网络编程:
tcp与udp的区别(必问)
udp调用connect有什么做用?
tcp链接中时序图,状态图,必须很是很是熟练
socket服务端的实现,select和epoll的区别(必问)
epoll哪些触发模式,有啥区别?(必须很是详尽的解释水平触发和边缘触发的区别,以及边缘触发在编程中要作哪些更多的确认)
大规模链接上来,并发模型怎么设计
tcp结束链接怎么握手,time_wait状态是什么,为何会有time_wait状态?哪一方会有time_wait状态,如何避免time_wait状态占用资源(必须回答的详细)
tcp头多少字节?哪些字段?(必问)
什么是滑动窗口(必问)
connect会阻塞,怎么解决?(必考必问,提示:设置非阻塞,返回以后用select检测状态)
若是select返回可读,结果只读到0字节,什么状况?
keepalive 是什么东东?如何使用?
列举你所知道的tcp选项,并说明其做用。
socket什么状况下可读?
db:
mysql,会考sql语言,服务器数据库大规模数据怎么设计,db各类性能指标
最后:补充一个最最重要,最最坑爹,最最有难度的一个题目:一个每秒百万级访问量的互联网服务器,每一个访问都有数据计算和I/O操做,若是让你设计,你怎么设计?