⭐️前言⭐️
本篇文章记录博主面试北京某公司所记录的面经,希望能给各位带来帮助。
🍉欢迎点赞 👍 收藏 ⭐留言评论 📝私信必回哟😁
🍉博主将持续更新学习记录收获,友友们有任何问题可以在评论区留言
🍉博客中涉及源码及博主日常练习代码均已上传GitHub
📍内容导读📍
- 🍅学了这么多开发知识,为什么选择走测试
- 🍅测试的流程
- 🍅在选取测试用例之前,测试人员需要做什么
- 🍅测试计划什么时候做?都有哪些东西
- 🍅提bug开发不认可
- 🍅在测试的时候测试环境没有问题,结果上了线之后出现的问题,这个时候你要怎么做
- 🍅一套测试用例写到什么程度才算完整
- 🍅等价类和边界值方法的运用
- 🍅A、B两个接口,如何实现接口之间的参数传递
- 🍅什么是多态
- 🍅什么是GC
- 🍅堆内存和栈内存的区别
- 🍅HTTP和HTTPS的区别
🍅学了这么多开发知识,为什么选择走测试
首先,个人对软件测试是比较感兴趣的,我喜欢在软件中发现错误、解决问题和提高软件质量;其次,软件测试需要的技能,比如测试计划、测试执行、测试自动化等等,我在这些技能方面比开发方面更有天赋;最后,软件测试岗位需要的一些特质和能力是比较契合我的,比如说沟通能力、耐心和细心等方面。
🍅测试的流程
一般包括以下步骤:
1、需求分析
根据软件需求分析文档,确定测试范围和重点,作为测试计划的基本依据
2、测试计划
软件测试贯穿软件的整个生命周期,根据需求分析结果来制定测试计划。
3、测试设计
根据测试计划设计测试用例,以保证对软件的功能、性能、界面、兼容性、易用性、安全性等各个方面进行全方面测试。
4、测试执行
参考测试用例来进行测试,记录测试结果,包括缺陷、异常、问题等。
5、测试报告
根据测试结果,编写测试报告。
6、测试评估
根据测试结果和测试报告,评估测试效果和质量,总结经验教训,为下一轮测试提供参考和改进建议。
🍅在选取测试用例之前,测试人员需要做什么
1、理解需求:了解软件的功能和业务流程。
2、制定测试策略:确定测试目标、测试环境、测试方法、测试数据、测试工具等。
3、分析风险:分析软件的潜在风险,并制定相应的测试计划和测试用例。
4、选择测试用例:根据测试策略和风险分析结果,选择适当的测试用例来覆盖软件的各个功能和业务流程。
5、编写测试用例:编写详细的测试用例,描述测试步骤、测试数据、预期结果等。
🍅测试计划什么时候做?都有哪些东西
测试计划需要在测试活动开始之前制定,通常包含以下内容:
1、测试目标:描述测试的总体目标,例如发现软件的缺陷、评估软件性能、验证软件的符合性等。
2、测试范围:描述测试的覆盖范围,包括测试的软件版本,功能模块,业务流程等。
3、测试时间:描述测试的时间安排,包括测试的开始时间、结束时间、测试周期等。
4、测试方法:描述测试的具体方法,例如手动测试、自动化测试、性能测试、安全测试等。
5、测试用例:描述测试用例的编写、管理和执行方式。
6、测试报告:描述测试结果的报告方式、格式和内容。
🍅提bug开发不认可
● 1.首先反思自己是不是bug描述的不够清楚
● 2.bug等级要有理有据
● 3.合理友好的沟通,站在用户的角度反问:如果你是用户,能够接受这样的体验吗
● 4.不仅能够提出问题,最好能够给出解决方案。
● 5.组织bug评审
邀请代表参加bug评审:产品代表、开发代表、测试代表,进行以下工作:
1)如何解决bug?
2)如何预防类似的bug?
🍅在测试的时候测试环境没有问题,结果上了线之后出现的问题,这个时候你要怎么做
1、收集问题信息:尽快了解问题的具体情况,包括问题的现象、发生的时间、影响的范围、重现的步骤等。
2、搜集日志和数据:搜集相关的日志和数据,以了解问题的根本原因。
3、分析问题原因:包括软件的设计、实现、集成、配置等方面,以确定问题的根本原因。
4、制定解决方案:制定相应的解决方案,包括修复缺陷、回滚版本、暂停服务等等。
5、实施解决方案:尽快实施相应的解决方案,以缩短问题的持续时间和减少影响范围。
6、验证解决方案:验证解决方案的有效性和稳定性,以确保问题已经得到解决,并且不会再次出现。
🍅一套测试用例写到什么程度才算完整
是否完整看的是对项目的测试覆盖率,我通常从功能、性能、界面、兼容性、易用性、安全性方面来考虑。
🍅等价类和边界值方法的运用
针对项目的一个点讲述了一下。
🍅A、B两个接口,如何实现接口之间的参数传递
1、GET请求的URL参数传递,接收参数的接口可以通过解析URL来获取传递的参数。
2、POST、PUT请求的请求体body传递,接收参数的接口可以通过解析请求体来获取传递的参数。
3、Cookie传递:将参数作为Cookie的值进行传递,接收参数的接口可以通过解析Cookie来获取传递的参数。
4、Session传递:将参数存储在Session中,由一个接口存储参数,另一个接口从Session中获取参数。
5、数据库存储:由一个接口将参数存储在数据库中,另一个接口从数据库中获取参数。
🍅什么是多态
多态是指一个对象可以表现出多种形态,在Java中,多态可以通过继承和接口实现。
主要在向上转型和动态绑定上体现
向上转型:父类引用指向子类对象
动态绑定:调用类的方法,究竟执行的是父类的方法还是子类的方法,要看这个引用指向的是父类对象还是子类对象,这个过程是运行时决定的,因此称为动态绑定。
🍅什么是GC
GC是指垃圾回收算法,有以下几种:
标记-清除算法:
标记就是可达性分析的过程,清除就是直接释放内存,但是被释放的内存是离散的,在需要申请内存时,并不能提供连续的内存,这将非常影响程序的执行。
复制算法:(为了解决内存碎片,引入复制算法)
把内存分为两部分,直接把不是垃圾的,拷贝到另一半,然后将原来的空间整体释放掉。
存在的问题:
● 内存空间利用率低
● 如果要保留的对象多,要释放的对象少,此时复制的开销很大
标记-整理算法:(对复制算法的改进)
具体的实现类似于顺序表中删除中间元素的操作(这个方法虽然空间利用率提高了,但是仍未解决复制/搬运元素开销大的问题)
分代回收算法:(多种方法的结合实现,JVM中实际应用的回收算法)
针对对象进行分类(根据对象的“年龄”分类),一个对象经历过一轮GC扫描,就认为是“长了一岁”,针对不同年龄的对象,采取不同的方案,这就是分代回收
在内存中划分出如下区域:
1、刚创建出来的对象,放在伊甸区
2、如果伊甸区对象经过一轮GC扫描,就会被拷贝到幸存区(应用了复制算法)
3、在后续的几轮GC中,幸存区的对象就在两个幸存区之间来回拷贝(复制算法),每一轮都会淘汰掉一波幸存者
4、在持续若干轮后,对象进入老年代,老年代中的对象比较老,也是继续存活的可能性大的,因此在老年代的GC频率大大低于新生代,所以在老年代中使用标记-清除算法或标记-整理算法的方式来进行回收。
🍅堆内存和栈内存的区别
1、分配方式:
堆内存是由程序员手动申请和释放的,而栈内存是由编译器自动分配和释放的。
2、管理机制:
堆内存的管理机制是动态分配,程序员需要手动申请和释放内存,而栈内存的管理机制是静态分配,编译器自动管理内存。
3、存储内容:
堆内存存储的是对象、数组等动态分配的数据结构,而栈内存存储的是局部变量和函数调用栈等。
4、存储大小:堆内存的大小一般比栈内存大,因为堆内存用于存储动态分配的数据结构,而栈内存的大小受限于编译器和操作系统的限制。
5、存储效率:堆内存的存储效率较低,因为需要程序员手动管理内存,而栈内存的存储效率较高,因为编译器自动管理内存。
🍅HTTP和HTTPS的区别
1、安全性不同:HTTP是明文传输协议,数据在传输过程中不进行加密,容易被黑客截取并篡改。HTTPS使用SSL/TLS协议进行加密传输,可以保证数据在传输过程中的安全性。
2、传输速度不同:HTTPS需要进行加密和解密操作,传输速度略慢
3、证书验证不同:HTTPS使用数字证书验证服务器身份,确保客户端和服务器端之间的通信安全,而HTTP协议没有进行身份验证,可能存在中间人攻击风险。
4、端口号不同:HTTP默认用80端口进行通信,而HTTPS默认用443端口进行通信。
⭐️最后的话⭐️
总结不易,希望uu们不要吝啬你们的👍哟(^U^)ノ~YO!!如有问题,欢迎评论区批评指正😁