秋阳的软件测试专栏

   :: 首页 :: 新随笔 :: 联系 :: 聚合  :: 管理 ::
  65 随笔 :: 0 文章 :: 127 评论 :: 0 Trackbacks
今天看到同事转发的‘软件开发者面试百问’,里面的一些问题放在非面试的场合,思考一下也很有意思。
下面是ZT的中文版,关于测试的几个问题,按照我的理解写了一些,放在了后面。
-----------------------------------------------------------------------------------------------

1月13日,著名博客作者Jurgen Appelo写了一篇博文:“软件开发者面试百问”。该文甚受读者欢迎,15日便登上了delicious,Popurls.com,Reddit的首页,这也是我见过考察范围最广的一个面试题集合。

原文见:100 Interview Questions for Software Developers

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

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

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

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

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

你可以把我的这些问题作为引子,展开讨论。例如下面有个问题是使用静态方法或是单例的缘由。如果那个面试的就此展开长篇大论,那他很有可能是个聪明能干的家伙!如果他一脸茫然的看着你,发出这种声音,很明显这就是只狒狒了。同样,想知道一个数是不是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. 如果客户想要的东西太多,你在范围和时间上怎样跟他达成一致呢?


对于上面的有些问题,我只想说:给我一只香蕉吧
因为对软件测试部分有一些了解,谈一谈自己的看法


测试


什么是回归测试?怎样知道新引入的变化没有给现有的功能造成破坏?
>
产品修正了bug或增加了功能,生成新的版本,对这个版本进行测试,就叫做回归测试。
保证变化没有对产品原有功能造成破坏,最可靠的方式是对产品进行全面的测试。还有一个方法是只对修改部分的相关部分进行测试,这是一种折中的方法,因为进度、成本的原因,这也是经常被采用的方法,这个方法有一定的风险,因为准确的确定产品修改部分的相关部分往往很有难度,范围不好确定。
具体采用哪种回归方式,要由这个产品的质量要求、人力资源、时间进度等因素来决定。
 

如果业务层和数据层之间有依赖关系,你该怎么写单元测试?
>
如果有了数据层的实现,就没什么问题了。提出这个问题,主要是在数据层没有实现的情况下,如何对业务层的代码进行单元测试?
这个时候我们需要模拟数据层,给业务层提供数据,比如简单的返回各类数据,直接从文本文件、数据库中读取我们需要的测试数据等来完成单元测试。


你用哪些工具测试代码质量?
>
针对代码的测试工具有很多,一般分2大类,是从执行测试的方式上分的,一是静态分析类,一是动态测试类。
静态分析类,特点就是不需要执行代码。象logiscope、C++ Test、LINT就属于这一类,主要是检测代码的编写规范,分析代码的复杂度、可能存在的隐患等等。这类工具在对可靠性要求较高的软件领域使用较多,比如航空航天。我们平时做的代码评审,就是在人工做这类工作。
动态测试类,主要是发现代码中诸如内存泄露、数据访问越界等这类错误,比如Compuware DevPartner、Rational PurifyPlus、valgrind这类工具。这类测试工具,要求测试代码必须运行起来,只有执行到的代码,存在问题才会被发现。没有执行到的代码即使存在问题也不能被发现。所以使用这类测试,一是靠工具,二是靠你制造的测试输入,如果测试输入不够丰富,很多bug是发现不了的。
还有一个很特别的工具PolySpacee,它打乱了上面的这个分类,它是采用静态的方式,却能够发现动态错误,即不需要制定和执行测试用例,只是静态扫描代码,就能够发现内存泄露这类问题。我是从一个好朋友那里了解到的,但没具体使用过,细节不是很了解。
象XUnit、覆盖率测试工具这类在代码测试中也会经常用到,但它们属于辅助性工具,本身不能对代码进行什么测试。


在产品部署之后,你最常碰到的是什么类型的问题?
>
产品发布后,特殊数据、特殊测试环境导致的问题比较多。易用性上,因为对用户的使用习惯不了解,可能会有有问题反馈。包括性能,因为对用户的实际使用规模估计不足,也可能导致问题。


什么是代码覆盖率?有多少种代码覆盖率?
>
代码覆盖率是单元测试里的概念,指测试结束后,被执行的代码或路径数量占总代码或路径数量的百分比。
语句覆盖、分支覆盖、路径覆盖是常见的几种覆盖率方式。
统计代码的覆盖率,一般都需要使用测试工具,人工很难做这项工作。


功能测试和探索性测试的区别是什么?你怎么对网站进行测试?
>
功能测试,需要依照事前制定好的测试用例来执行测试。
探索性测试,不会事前制定测试用例,是在测试中边设计边执行。其实在功能测试中也有探索性测试的使用,因为测试用例不可能细化到每个细节,测试人员在执行时肯定会做一些探索性测试。探索性测试一般在测试初期对产品不了解时,或者到了后期在现有测试用例基础上发布不了bug时使用。还有在安全性测试中,探索性测试肯定要经常被用到。
怎么对网站进行测试?不知道为什么要放到这个问题里来。网站除了一般性的功能测试外,性能、安全性测试也是必须要进行的测试内容。类似安装卸载、升级这类产品测试中关注的内容,网站测试就不需要关注了。


测试套件、测试用例、测试计划,这三者之间的区别是什么?你怎么组织测试?
>
先从大的说。
测试计划是指导整个测试过程的一份概述文档,包括测试范围、测试策略、人力物力资源、时间进度、风险分析等内容。
测试套件,是测试用例的一个大的分类,按照逻辑,或者说按照测试组的理解把测试用例划分成不同的部分,每个部分就是一个test suite。
测试用例,最底层的测试产品,实际覆盖产品各个功能点、非功能点的测试。如果用过XUnit工具,应该对test suite、test case这样的划分不陌生。


要对电子商务网站做冒烟测试,你会做哪些类型的测试?
>
冒烟测试,主要目的是通过执行较少或较简单的测试用例,验证产品基本功能是否正常。如果这个测试都没有通过,就没有必要投入人力进行后续的测试工作了。
对电子商务网站理解的不多,如果是我对电子商务网站进行冒烟测试的话,我会执行:用户注册,登陆,检索,挑选商品、购买、付账这些测试,每类只做一项基本测试。另外保证每个链接都是有效的。


客户在验收测试中会发现不满意的东西,怎样减少这种情况的发生?
>
可能比较多的情况是:有些功能实现不是用户想要的;不满足特殊的行业要求;性能没达到用户的要求;使用习惯、易用性不符合用户要求等等这类。比较好的方式是渐近的给用户提供产品,让用户能在产品的不同开发阶段介入,提出意见,每个阶段都进行相应的测试。如果用户能作为开发测试组的一员,那就更好了。

posted on 2009-02-05 13:17 qiuyangzh 阅读(1391) 评论(6)  编辑 收藏 引用 所属分类: 06 测试管理/软件过程

评论

# re: 关于‘软件开发者面试百问’ 2009-02-06 11:31 游子
好东东,我收藏了  回复  更多评论
  

# re: 关于‘软件开发者面试百问’ 2009-02-06 11:32 游子
哪里有答案 ?  回复  更多评论
  

# re: 关于‘软件开发者面试百问’ 2009-02-06 11:50 qiuyangzh
这种东西,每个人都会有自己的理解,不会有什么统一的答案  回复  更多评论
  

# re: 关于‘软件开发者面试百问’ 2009-02-08 13:34 IT公司面试手册
看来这个文章确实很流行 呵呵  回复  更多评论
  

# re: 关于‘软件开发者面试百问’[未登录] 2009-02-24 11:48 SUNNY
@游子
答案在香蕉里~~  回复  更多评论
  

# re: 关于‘软件开发者面试百问’ 2009-04-16 18:25 天空下下雨
我是只狒狒  回复  更多评论
  

只有注册用户登录后才能发表评论。