软件开发者面试百问

作者 Jurgen Appelo译者 李剑 发布于 2009年1月20日 上午2时2分

以下为文章全文:


想雇到搞软件开发的聪明人可不容易。万一一不小心,就会搞到一堆低能大狒狒。我去年就碰到这种事了。你肯定不想这样吧。听我的,没错。在树上开站立会议门都没有。

问点有难度的问题能帮你把聪明人跟狒狒们分开。我决定把我自己整理出来的软件开发者面试百问发出来,希望能帮到你们的忙。

这个列表涵盖了软件工程知识体系中定义的大多数知识域。当然,如果你只想找出类拔萃的程序员,便只需涉及结构、算法、数据结构、测试这几个话题。如果想雇架构师,也可以只考虑需求、功能设计、技术设计这些地方。

不过不管你怎么做,都要牢记一点:

这里大多数问题的答案都没有对错之分!

你可以把我的这些问题作为引子,展开讨论。例如下面有个问题是使用静态方法或是单例的缘由。如果那个面试的就此展开长篇大论,那他很有可能是个聪明能干的家伙!如果他一脸茫然的看着你,发出这种声音,很明显这就是只狒狒了。同样,想知道一个数是不是2的乘方也有很多方法,不过要是面试的人想用mod运算符,嗯……你知道我的意思吧。(你不知道也没关系,来根香蕉?)

需求

  1. 你能给出一些非功能性(或者质量)需求的例子么?
  2. 如果客户需要高性能、使用极其方便而又高度安全,你会给他什么建议?
  3. 你能给出一些用来描述需求的不同技术么?它们各自适用于什么场景?
  4. 需求跟踪是什么意思?什么是向前追溯,什么是向后追溯?
  5. 你喜欢用什么工具跟踪需求?
  6. 你怎么看待需求变化?它是好是坏?给出你的理由。
  7. 你怎样研究需求,发现需求?有哪些资源可以用到?
  8. 你怎么给需求制定优先级?有哪些技术?
  9. 在需求过程中,用户、客户、开发人员各自的职责是什么?
  10. 你怎么对待不完整或是令人费解的需求?

功能设计

  1. 在功能设计中有哪些隐喻?给出几个成功的例子。
  2. 如果有些功能的执行时间很长,怎么能让用户感觉不到太长的等待?
  3. 如果用户必须要在一个很小的区域内,从一个常常的列表中选择多个条目,你会用什么控件?
  4. 有哪些方法可以保证数据项的完整?
  5. 建立系统原型有哪些技术?
  6. 应用程序怎样建立对用户行为的预期?给出一些例子。
  7. 如何入手设计一组数量庞大而又复杂的特性,你能举出一些设计思路吗?
  8. 有一个列表,其中有10个元素,每个元素都有20个字段可以编辑,你怎样设计这种情况?如果是1000个元素,每个元素有3个字段呢?
  9. 用不同的颜色对一段文本中的文字标记高亮,这种做法有什么问题?
  10. Web环境和Windows环境各有些什么限制?

技术设计

  1. 什么是低耦合和高聚合?封装原则又是什么意思?
  2. 在Web应用中,你怎样避免几个人编辑同一段数据所造成的冲突?
  3. 你知道设计模式吗?你用过哪些设计模式?在什么场合下用的?
  4. 是否了解什么是无状态的业务层?长事务如何与之相适应?
  5. 在搭建一个架构,或是技术设计时,你用过几种图?
  6. 在N层架构中都有哪些层?它们各自的职责是什么?
  7. 有哪些方法可以确保架构中数据的正确和健壮?
  8. 面向对象设计和面向组件设计有哪些不同之处?
  9. 怎样在数据库中对用户授权、用户配置、权限管理这几项功能建模?
  10. 怎样按照等级制度给动物王国(包括各种物种和各自的行为)建模?

程序设计

  1. 你怎样保证你的代码可以处理各种错误事件?
  2. 解释一下什么是测试驱动开发,举出极限编程中的一些原则。
  3. 看别人代码的时候,你最关心什么地方?
  4. 什么时候使用抽象类,什么时候使用接口?
  5. 除了IDE以外,你还喜欢哪些必不可少的工具?
  6. 你怎么保证代码执行速度快,而又不出问题?
  7. 什么时候用多态,什么时候用委派?
  8. 什么时候使用带有静态成员的类,什么时候使用单例?
  9. 你在代码里面怎么提前处理需求的变化?给一些例子。
  10. 描述一下实现一段代码的过程,从需求到最终交付。

算法

  1. 怎样知道一个数字是不是2的乘方?怎样判断一个数是不是奇数?
  2. 怎样找出链表中间的元素?
  3. 怎样改变10,000个静态HTML页面中所有电话号码的格式?
  4. 举出一个你所用过的递归的例子。
  5. 在散列表和排序后的列表中找一个元素,哪个查找速度最快?
  6. 不管是书、杂志还是网络,你从中所学到的最后一点算法知识是什么?
  7. 怎样把字符串反转?你能不用临时的字符串么?
  8. 你愿意用什么类型的语言来编写复杂的算法?
  9. 有一个数组,里面是从1到1,000,000的整数,其中有一个数字出现了两次,你怎么找出那个重复的数字?
  10. 你知道“旅行商问题(Traveling Salesman Problem)”么?

数据结构

  1. 怎样在内存中实现伦敦地铁的结构?
  2. 怎样以最有效的方式在数据库中存储颜色值?
  3. 队列和堆栈区别是什么?
  4. 用堆或者栈存储数据的区别是什么?
  5. 怎样在数据库中存储N维向量?
  6. 你倾向于用哪种类型的语言编写复杂的数据结构?
  7. 21的二进制值是什么?十六制值呢?
  8. 不管是书、杂志还是网络,你从中所学到的最后一点数据结构的知识是什么?
  9. 怎样在XML文档中存储足球比赛结果(包括队伍和比分)?
  10. 有哪些文本格式可以保存Unicode字符?

测试

  1. 什么是回归测试?怎样知道新引入的变化没有给现有的功能造成破坏?
  2. 如果业务层和数据层之间有依赖关系,你该怎么写单元测试?
  3. 你用哪些工具测试代码质量?
  4. 在产品部署之后,你最常碰到的是什么类型的问题?
  5. 什么是代码覆盖率?有多少种代码覆盖率?
  6. 功能测试和探索性测试的区别是什么?你怎么对网站进行测试?
  7. 测试套件、测试用例、测试计划,这三者之间的区别是什么?你怎么组织测试?
  8. 要对电子商务网站做冒烟测试,你会做哪些类型的测试?
  9. 客户在验收测试中会发现不满意的东西,怎样减少这种情况的发生?
  10. 你去年在测试和质量保证方面学到了哪些东西?

维护

  1. 你用哪些工具在维护阶段对产品进行监控?
  2. 要想对一个正在产品环境中被使用的产品进行升级,该注意哪些重要事项?
  3. 如果在一个庞大的文件中有错误,而代码又无法逐步跟踪,你怎么找出错误?
  4. 你怎样保证代码中的变化不会影响产品的其他部分?
  5. 你怎样为产品编写技术文档?
  6. 你用过哪些方式保证软件产品容易维护?
  7. 怎样在产品运行的环境中进行系统调试?
  8. 什么是负载均衡?负载均衡的方式有哪些种?
  9. 为什么在应用程序的生命周期中,软件维护费用所占的份额最高?
  10. 再造工程(re-engineering)和逆向工程(reverse engineering)的区别是什么?

配置管理

  1. 你知道配置管理中基线的含义么?怎样把项目中某个重要的时刻冻结?
  2. 你一般会把哪些东西纳入版本控制?
  3. 怎样可以保证团队中每个人都知道谁改变了哪些东西?
  4. Tag和Branch的区别是什么?在什么情况下该使用tag,什么时候用branch?
  5. 怎样管理技术文档——如产品架构文档——的变化?
  6. 你用什么侗剧管理项目中所有数字信息的状态?你最喜欢哪种工具?
  7. 如果客户想要对一款已经发布的产品做出变动,你怎么处理?
  8. 版本管理和发布管理有什么差异?
  9. 对文本文件的变化和二进制文件的变化进行管理,这二者有什么不同?
  10. 同时处理多个变更请求,或是同时进行增量开发和维护,这种事情你怎么看待?

项目管理

  1. 范围、时间、成本,这三项中哪些是可以由客户控制的?
  2. 谁该对项目中所要付出的一切做出估算?谁有权设置最后期限?
  3. 减少交付的次数,或是减少每个每个交付中的工作量,你喜欢哪种做法?
  4. 你喜欢用哪种图来跟踪项目进度?
  5. 迭代和增量的区别在哪里?
  6. 试着解释一下风险管理中用到的实践。风险该如何管理?
  7. 你喜欢任务分解还是滚动式计划?
  8. 你需要哪些东西帮助你判断项目是否符合时间要求,在预算范围内运作?
  9. DSDM、Prince2、Scrum,这三者之间有哪些区别?
  10. 如果客户想要的东西太多,你在范围和时间上怎样跟他达成一致呢?
posted @ 2009-01-21 11:37 bestshl 阅读(190) 评论(1) 编辑
转自:http://blog.sina.com.cn/s/blog_49c8645e01009ba8.html

天佑中国,人间有爱,刚听到的消息 (2008-05-13 19:43:30)

本来想今天更新,但是看到了新闻,实在没有了心情。

 

刚刚接通了一位采访过我的四川记者朋友的电话,她刚刚从绵竹退下来,这个娇小的丫头在电话里和我讲了她眼见的情况,她只用了四个字形容,就是:“世界末日。”她说她几乎无法工作,眼泪就没有停过,太惨了,一片一片的废墟,到处是哭喊的声音,救援队发了疯一样的救人,然而往往救不了,跟着去的摄影只了拍一张照片,就扔下相机去帮忙,因为那情景让你不可能站着看着。

 

她和我说,她在一个学校现场看到了她永远不会忘记的一幕,学校的主教学楼坍塌了大半,当时正在上课,几乎有100多个孩子被压在了下面。全是小学生。一些似乎是消防队员的战士在废墟中已经抢出了十几个孩子和三十多具尸体,看着那些小小的,带着红领巾却再也无法睁开眼睛的孩子,她说她突然觉得自己说话的勇气都没有了。

 

然而就在抢救到最关键的时候,突然教学楼的废墟因为余震和机吊操作发生了移动,随时有可能发生再次坍塌,再进入废墟救援十分的危险,几乎等于送死,当时的消防指挥下了死命令,让钻入废墟的人马上撤出来,要等到坍塌稳定后再进入,然而此时,几个刚才废墟出来的战士大叫又发现了孩子。

 

几个战士听见了就不管了,转头又要往里钻,这时坍塌就发生了,一块巨大的混凝土块眼看就在往下陷,那几个往里转的战士马上给其他的战士死死拖住,两帮人在上面拉扯,最后废墟上的战士们被人拖到了安全地带,一个刚从废墟中带出了一个孩子的战士就跪了下来大哭,对拖着他的人说你们让我再去救一个,求求你们让我再去救一个!我还能再救一个!

 

看到这个情形所有人都哭了,然而所有人都无计可施,只眼睁睁的看着废墟第二次坍塌。后来,那几个小孩子还是给挖出来了,但是却只有一个还活着,看着那些个年轻的战士抱着那个幸存的小女孩在雨中大叫着跑向救援所在的帐篷的时候,她已经泣不成声。

 

我无法想象这在电话中已经如此惊心动魄的情形在当时是怎么样一个悲壮的场面,我只知道这是真实的,而且,在现在,在震中地区,这样的事情还在重复的发生着,就在今夜,我坐在舒适的房间内,第一次意识到我是否应该做些什么,虽然我不可能到现场去,但是我是否应该做一些力所能及的事情?

 

于是我眼含着眼泪,首先发了这一篇博文,我知道这篇博文无法带来什么实际的帮助,但是,这是我想到的最便捷的,我所能立即做到的第一件事情,一篇文虽然没有力量,但是至少我可以让更多的人关注这件事情。只有完成了第一件事情,才有第二件,第三件。

 

天佑中国,人间有爱。朋友们,无论你们身边有任何的条件,只要是能帮助灾区的,希望我们都马上付之行动,莫以善小而不为,一篇文章,一元捐款,都是一种支持,2008注定是荣耀与灾难交辉的一年,灾难的是中国人的土地,荣耀的是中国人的心。


posted @ 2008-05-15 09:00 bestshl 阅读(59) 评论(0) 编辑
我的座驾见谁灭谁!

我的座驾见谁灭谁!
我的凤凰,黑色28脚动,买了2年零4个月,5000公里了。总的来讲,除了做工粗糙了点,的确能算一部好车!一直使用比较顺畅,保养得也比较好,现在看来还象新车一样。 

1、磨合期 

  我的磨和期是跑得不错的,10公里内没超过8;20公里内没超过10;30公里内没超过12。30公里后,拉过一次高速,到了极限21公里/62转(再加就要进医院了)。后来行车都保持20转换挡,15转行车。偶尔也1、2、3挡提到45转。所以的我的脚动波显得特别的灵敏,提速比较快。(可能是脚蹬子已经习惯了我的驾驶习惯吧!) 

  2、改装 

  我基本没动过要改装机械部分的心思,因为我觉得凤凰现在的状况已经不错了,至少够我用的了。在提车时我就改装了真皮坐椅。当然没有选俗气的黑色装饰,而是选择了金属银。换了VTS单幅把手!,不过说实话,的确好看了许多,有了点赛车的意思。还加装了前大灯,哎!咱也恶心一回吧,冒充电动车吧!不过说实话,外观挺美,黄乎乎的,可就是不顶用,在路灯下基本象没开灯一样。除非在特别黑的时候,也就是没有其他任何光源的时候,才能体现出它的优势。也就是说,瓦数太低,只是在物体的反射上有一定的优势。所以这项改装是失败的,本想换回来,可又心疼那**米,哎!真是进退两难啊!我还对音响进行了改动。换了不锈钢的玲裆12大米(特价);个人感觉不错,比以前有了质的飞跃,当然比不了那些顶级发烧友的,对我言已经足够了.好了再和大家来分享一下对凤凰的驾驶感受吧: 

  1、提速 

   

  提速慢、起步肉,一直是针对28大车的敏感话题。个人认为应该是驾驶习惯造成的。都说飞鸽、GIANT的提速快,凤凰、永久的提速肉。可是应该考虑到车子的类型不同。这几款车我都开过,FG、GIANT在正常情况下提速的确不错,不需要把转速提得很高就能提供不错的动力,但过了承重40kg以后动力就显得不够充分了。而凤凰28呢,不信你把承重提到45-50kg起步试试,看看哪辆车能超过你。大凤凰车系都是高转速发动机,需要把转速提起来才能显示其充沛的动力。我试过下坡起步,从未遇见过对手。有一次遇到一辆永久,咬上了,我硬是连续3个红绿灯超它半个车身。都是原地使劲,起步时后轮原地空转,轮胎和地面磨得青烟直冒。凤凰还是胜了。特别值得一提的是凤凰在16-18码时还有推臀感,这点在28排量的车系中是难能可贵的,这也正是高转速发动机的特点所在啊! 

  2、过弯 

  凤凰的车架、悬挂和前轮主动转向真是一绝,过弯时车身的稳定性在200以内的车型中绝对首屈一指。这个性能曾救过我一命啊!北京的朋友应该都知道,北京二环东直门上机场高速,限速6。有一天早上,我送1个朋友去机场,由于赶时间,车开得特别快。到弯道时,限速牌被遮挡,没有及时减速。以14的速度进了弯。大家想想,超过限速50%将是极限,我又何止超过了100%。当时就觉得车不听使唤了,对着隔离墩就过去了。我开始一惊,马上冷静下来,没有去踩刹车,双手死死地抓住车把,匀速地打方向,就看见左脚蹬子檫着隔离墩过去了。过来后感到全身都汗湿了,太危险了,后边的轮胎都离地了。这种感觉太恐怖了,真正和死神打了个照面啊!后来想想还真亏了凤凰了,要是换了其他的什么车,后果不堪设想啊! 

  3、刹车 

  开宝马的人再去开其他车,总觉得动力不足;开了我的凤凰再去开其他的车,总是觉得刹车不灵。真不是吹的,我觉得凤凰的机械拉线刹车,比很多电子ABS刹车的效果还要好。我的朋友们开了我的车后第一句话就是刹车好。不知大家的感觉如何?记得06年11月在从公司回家的路上,和一辆崭新的GIANT咬上了。我当时正以16的时速一路超车,突然一辆黑色GIANT从行车道嗖地一下把我超了,然后马上变到超车道,既没打转向也没有闪灯提示,根本没把凤凰放在眼里。我有点恼火,呼的一脚就跟了上去。我变到行车道,加到18时和GIANT平行了。GIANT的司机发现了我的企图,非常轻蔑地看了我一(真的,两车平行时,我们对视了一眼,我清晰地看见了他的眼神)。GIANT猛地向前窜去。我也一脚把踩到了底。凤凰的潜能充分展现了,随着耳边的轰鸣,有了强烈的推背感。凤凰丝毫不比GIANT逊色,居然还超过了半个车身。就这样一直到了20。GIANT还是差了半个车身。这时突然发现前方10米处有一辆永久在超车道上行驶。按理说这时GIANT应该减速了,但他居然还在加速,想超过我,变到行车道上来。我没给他机会,提速到了21。就这样,一黑另一黑两辆车同时以21码的速度向永久接近。就在离永久大约3米时,永久好象发现了飞鸽,打着右转手势要变到行车道。我一下吓蒙了,一边打玲,一边一脚刹车狠狠地踩了下去。永久这时也发现了我,立即停止了变道,稳在了超车道和行车道中间。我猛地打了一把方向,和GIANT一左一右檫着永久冲了过去。那种感受直到今天我还记忆犹新。凤凰的刹车确实太棒了,21码的速度,不但减了速,没有丝毫前后轮抱死和侧滑现象,而且还能打方向。这可是我的亲身经历啊。 

  4、高速上,凤凰见谁灭谁 

  我开过很多车型,也属于爱车一族。我们家还有一辆蓝色的24小永久,读中学时开的。根本不能和我的大凤凰相提并论。我的朋友也都大部分是有车一族,什么捷安特at、永久mt、凤凰手自一体、还有豪华的绿亮电动车基本含盖了我们这地方现在有代表性的车型。这些车我都开过,而且都比较了解。就单从高速表现而言凤凰应该和捷安特、绿亮电动车在同一个档次上,比同级别的车型高出了很大一截。200以内的车型中能有几辆能在20-21的速度上保持良好的操控性能?我曾经在机动车道上把一台奥迪A6,3.2超的竖大拇指。当时北京东直门内大街机动车道上,我被一辆奥迪A6,3.2超车。当时路况极好,车多人多,红绿灯多,于是乎童心大起,想和他玩玩。奥迪保持18的速度前进,我没去超车,就是也以18的速度隔0.2米跟着他。刚开始他还没在意,后来他发现了我。大家都是开车的,应该都知道在行车时有一辆车老是跟在后面不是很爽。奥迪开始加速了,想甩掉我。19,我跟了上去,还是保持0.2米的距离。这样跑了1分钟。奥迪又减速到18,我也减,始终保持0.2米的距离。就这样20、18、21持续了大约2分钟。前方的奥迪减速了,打右转向灯靠边停车。车窗里伸出一只手,打着手势让我上前。我开到和他平行看见奥迪的驾驶员和我打招呼,伸出了大拇指。我也非常友好地回应了他。


posted @ 2008-04-10 09:09 bestshl 阅读(19) 评论(0) 编辑