|
|
IT名企面试经验汇总
0 ]) P; n1 ?$ i# s: K( M- X. V) n, k+ G2 }8 |2 T
5 V0 [6 A9 {- m; T& c一:09.21 – 有道三面 – 余总
* o# r3 l& D5 E! T0 Z- @% C8 _
, M9 F$ s( y2 _* u9 o3 G# o1 B! {& e& e+ O# g$ p6 r# j
infrastructure/基础架构组。三面算是终面,说一周内给结果。( [, E9 }" A# f' u, Y
: a8 @7 B0 A0 u& C8 G$ K3 o6 H( I聊简历,问做过的最感兴趣的项目、问实习、问"你认为自己有什么缺点”,然后做题:7 {: ^2 a9 }* c7 I
1 X: X% A" F3 K" _1 s
Coding
0 v2 n' ~+ X1 i" W& p# p- ~# r4 Q给一个字典,并且这个字典是用一个字符串保存的。里面是很多很多个单词,单词之间用\0分割,且这些单词按照字典序排列。写出查找算法,要求能够较快地查找一个单词是否在字典中。 k3 z- m9 d2 a/ ~5 {8 J
例如包含四个单词的字典看起来如下:8 m% [" e8 {& D% I4 C. M$ U
dict[]=a\0am\0b\0\bt\0
2 M! { D$ T& u! C" r包含了a、am、b、bt四个单词。0 Z( z+ r+ G! l7 V8 t' [1 A) o
const char* dict = ...;
' g" f: W5 w: o1 N/ o0 G0 V! j* J- @int dict_len = LEN;0 t6 M- O7 u. _" ]3 ~
bool find(const char* dict, int dict_len);
; z$ Q5 P6 _" f1 V/ D- h! @) {/ C, u& B# q
tips: 不准建索引,不准建查找树。
5 \# y, [7 F. h; q
% e3 q# A0 ~, L4 ^/ jDesign2 M* G5 _- f% b4 h. l" t
设计出一种磁盘管理方法,要求写性能特别好,读性能一般。
; f8 ~! g& I6 K# [: ftips: 1.磁盘寻道时间很慢 2. 磁盘读写连续块的速度很快
2 S* H) ]1 L- g) U9 j9 \. }6 u1 U* |, W/ f
, k2 p9 U# J2 U# F8 ^, L
二:08.12 – 百度1,2,3面 - 歌后
6 G" V1 n$ Y! _: ?0 Z1 A2 H- s6 z+ {2 U( G& \4 r
* L. Y3 _) `, Q! J. g0 [. O/ C& U% p" k; a' B! y$ D
应广大找工作同学的要求,经过了百度一面二面和我认为半个三面的我也写一下我的处女面面经。这部分面经具有非普适性,应为走的是内推流程,现在也不是招聘高峰,可能面试相对不是很刁难。
' N2 S& z3 k2 e [总的来说一面和二面问的内容都差不多,围绕项目谈一些项目相关的技术问题,技术问题注重实用性。由于我报的系统部网络组是做内核协议栈优化的,针对我的项目经历,主要就问了内核的一些应用问题,很基础也不太刁难,不会的我就直接说不会或者不确定。下面晒晒题目:
& \3 F9 i3 k. L/ {( k& X7 \
* [( a' M% n( ^* F; |' [% I7 h内核相关的
0 p' G1 ?8 N! u1 i++是不是原子操作?c语言中什么样的语句是原子的?$ D3 P' J+ n2 t+ O1 |' Q0 g3 ^
2 内核的分配函数有哪些,有什么区别?6 M$ `0 I- H. Y) ?$ u4 ]9 L
3 vmalloc分配大小有上限吗?) h0 n, G4 z. F+ [
4 原子变量一般在什么场景用?原子变量的使用位数有限制吗?& B2 [) d0 a6 X5 a1 A
5 spin_lock和mutex有什么区别?
! A- m1 v* C6 u/ Q- o6 在软中断中用什么锁?需要注意什么?& F; f# ?' w- ~4 O* |5 Q/ w
7 如何实现大量数据从内核态导出到用户态?
8 \4 [4 l3 q" ~7 _
+ c; t! t l, P1 R! l$ R$ m' zc相关的1 q l- Q8 o# a/ Y+ z8 j5 b
1下面这个函数有没有问题,输出是什么? `0 U+ r# |+ t4 Y! G
int main(int argc,char **argv){2 s5 X" n, ]1 D1 `' B( k5 |! \
int x[3]={1,3,5};
" E8 F6 D2 i) d! U* d2 e5 j/ d2 T5 _ printf("%d %d\n",*x,*x++);
2 X3 X' ` w+ K. P9 Y% w}
' Q1 Y9 m0 F$ i3 s% `2 计算ab两个整数中bit位不同的个数。有没有0(1)的算法?
+ h# c" l4 g9 J8 H& d9 r* j9 t
) k9 o$ J' r: J5 M+ b1 {9 y9 B项目相关的+ [6 s, p0 w j
面试的过程主要是讲自己的项目经历,在讲的过程中对方会针对他们的需要,或者他感兴趣的点进行提问。比如向他介绍他感兴趣的模块,你需要用比较直观和简洁的方法让别人懂你做的东西。另外注意,别人可能会问项目之外的东西,比如这个系统用的设备是什么样的等等。所以在准备项目的时候,深度扩展的同时,也别忘记广度,在宏观上的一些把握可能会为你的面试加分。
/ r+ V0 s: p& t( Y8 \) r) O总的来说,这两面的面试官态度都非常谦和,能够从他们身上感受到百度平等自由的工作氛围。最后的半个面试我不知道算不算三面,二面结束后他们就来了一个他们的老大,貌似是系统部的老大过来,没有问技术问题,就问职业规划,能不能实习之类的问题。说起职业规划还有一个小插曲,这个问题我之前跟QQ讨论过,我们的答案是先做技术再转管理,技术做3到5年,说3年一下别人会以为你不踏实,说5年别人会觉得你笨。所以我当时就说了个3年。没想到那个技术经理说我对自己的要求太宽松了,3年时间太长了。然后他就谈到百度现在极度扩张,需要大量管理人才,给我举例面试我的那些人的例子,总之意思就是百度的发展空间很大。。。总之,吸取教训,以后不跟人说做技术做几年了。。。
- L! }3 {9 b5 e! S& ^* Y/ o4 h* P# \2 ?* M+ ~) J8 o
5 X- I( G8 m$ A
三:09.28 – 腾讯面试 – 周总+ E3 F7 }( b$ R% y
# V [, f" q1 F2 d# {2 V
5 w! Z$ c9 X4 f& z0 Y$ G1、一面
5 S, p8 e6 k5 j) O6 d% r4 @6 y给我打电话的人,感觉很厚道。
& C7 b8 H! v, V; T主要是聊经历,问问题比较少。
6 C5 e) h/ i7 t! r6 f- w3 R# N8 }1.1 100个字符串,如何查找他们的公共字符串 k9 Y6 ^ V/ ]9 [1 D0 D& L
1.2 在地图搜索中,如何设计求任意两个公交站的最好换乘路线3 s3 c+ {( I8 S: o1 F7 u
w1 b6 h: J: k+ F3 H2、二面# E- U; F6 ~- K# H4 {
自动化所毕业的,算是校友; t' w6 H$ q3 E( ~. h( a
主要问设计:如搜索者打错了字,该怎么处理。5 v- I" Y% Y% d; @4 j' }) I& K
如何设计差异化的搜索结果。 M6 |" }( g7 B& @
现场写一个计算器的程序,就是已知表达式求值。
$ S! O/ `0 J% | 7 I2 B+ x, X1 \+ H
他们都会问些简历的经历。, e" R# [/ _" o2 w8 G3 l( x- D
8 B: m% s/ J5 j. u
" o, z9 N9 s, `7 d四:10.18 – Intel面试 – 耗子. }" ~# v+ @- j
8 e& w2 ?2 p* }- T
! S+ v& o) q; j& a: ^: c. b7 Y一面
" K" f' q! F0 l) v/ z# V* R5 {: uVFS层结构。面向过程和面向对象的区别。static关键字。进程的地址空间。面向对象的特性,继承封装多态,问了下覆盖。template method设计模式。IoC,依赖注入。' ^+ I' H$ d: ~" T F
malloc和free实现,野指针。7 s5 Q6 ~7 {- m( @. y
怎样快速找到单向链表的中间结点。! E6 ~, ~; g, i) s
" P- S, \ U" m, Z0 o* Z/ b
3 L1 _& s, J/ j/ K3 q! _
二面
5 m" X4 P. |( s+ `# F' \8 _3 K6 C4 A项目系统架构,x86,IA64体系结构的特点,arm和x86对比的优势劣势,交叉编译。在kernel开发中的debug方式。4 E p6 E8 W9 ^- \# `! l$ e
( Q. W( `$ ^& ~+ K
三面
1 ?" e2 r$ k5 R) s, h" i% ~- G3 a询问开源相关工作,git,讨论了下kernel开发中的内存分配。
6 R( }" D5 B$ m# h; a$ [6 `
: w. _7 T( d+ ?$ S7 Y# K! r! f% F6 Z* M$ G8 C
四面
+ l, V! F; F+ u% l聊了下benchmark和Linux IO系统,聊了下移动计算的发展前景,问我假如给offer去不去上海,来不来实习,还考虑不考虑别的公司。聊了下他们UMG在Intel中的整个地位。最后英语面试,描述自己最近的项目以及自己在其中的职责,遇到什么问题,怎样去解决,以及对自己的评价。! U. d Y. s) y; ?' O
6 K A0 O& |. k+ d- Q$ f% b
以上文章出自阿凡提求职手册——IT行业篇。免费下载更多的行业/企业求职手册,请您关注:3 ~! P3 R3 c8 | Y6 R* q3 F: g
http://www.aftjob.com/personal.php* J/ e8 f% F; v
|
|