大家好,我是洋子。最近工作真的超级忙,有几个同事离职,除了进行业务测试,还要进行工作交接,几乎没剩下什么空闲摸鱼时间,所以好久都没有更文章了
前段时间在公众号发布了一个百度测开实习招聘岗位,很高兴的和大家宣布,有一个粉丝同学顺利拿到了这个实习offer,未来将由洋子作为mentor来亲自带他实习
虽说以前也有稍微带过3个校招同学,帮助他们解答问题,但第一次以mentor身份带实习生还是第一次,想想还有点小激动
下面给大家分享3篇面经,第一篇为百度测开实习面经,后两篇为百度23届秋招提前批测开面经
下面给大家分享一下,他在百度测开实习的三轮面试真题,这个同学学历为科班硕士,从面试官角度来看,因为是实习岗位,以下的面试题比正式秋招测开岗稍微简单些,大家可以对照参考
从考察范围来看,这次面试题还是比较具有代表性,涵盖的考察的范围有简历上的项目经历、操作系统、计算机网络、数据库、算法题、Linux命令、测试用例设计、个人基本素质等
原文链接:https://www.nowcoder.com/discuss/1029917?source_id=discuss_experience_nctrack&channel=-1
自我介绍,(自我介绍太长了很明显感觉到面试官有点不耐烦了。。)
项目介绍;
深挖项目,介绍项目中Redis的使用,二次缓存的一致性保证,数据库持久化是怎么做的等等;
最常用的语言?(Java),会不会Python?(回答不会,面试官答没关系来了再学,很快),然后开始八股文;
面向对象七大设计原则;
String、StringBuffer、StringBuilder的区别;还知不知道其他不可变类,如何自己实现一个不可变类;
Java中不同类型的对象在JVM内存结构中存储的位置;
什么是泛型,泛型擦除一定会发生吗;
什么时候服务端会发生大量time_wait和close_wait状态;
手撕算法:实现一个算法,找到两个有序数组所有元素一起的中位数;
针对自己的接口,设计测试用例;
反问。
总结:算法题做的不太好,改半天。
一面结束半个小时通知通过,约下午二面。
自我介绍;
项目介绍;
追问项目;
实习做的都是开发工作,为什么选择测试;
基本的测试流程;
黑盒白盒测试的测试用例设计方法都有哪些;
介绍一下单元测试和冒烟测试;
讲十个Linux的基本指令;
说一下你对SpringBoot和Spring的区别的理解;
SpringBoot自动装配机制的原理;
SpringBoot IOC容器的设计目的,原理,以及依赖注入的方式;
知道哪些设计模式,单例模式懒汉式口述一下怎么写,volatile的作用是什么;
手撕代码:KMP字符串匹配算法;
针对一个零售机进行测试用例设计;
反问。
总结:KMP算法记得不太清楚了,模模糊糊地在面试官的引导下写出来的。测试用例设计这块掌握的还是不太好。
二面结束第三天主管直接打电话约三面。
自我介绍;
项目介绍;
超级深的深挖项目,深到每一个功能点的算法是怎么实现的。。。
为什么选择测试开发;
针对一个IP地址校验的接口进行测试用例设计;(答的不好,面试官后来说是想让我给出具体的关键数据的测试用例)
shell编程会吗,能不能大概介绍一下某个具体的语法;
为什么选择北京;
是考研还是保研的,为什么读研不选择计算机类专业;
讲一个逆袭的经历;
讲一个定下目标但最终放弃了的经历;
讲一个你最讨厌室友的哪一点(???);
反问;
原文链接:https://www.nowcoder.com/discuss/1022439?source_id=discuss_experience_nctrack&channel=-1
事业群:MEG
base:北京
一面:2022.8.12
时长:50min
select student_id
from student
order by grade desc limit 10
class Solution {
public boolean isValid(String s) {
Map<Character, Character> map = new HashMap<>();
map.put(')', '(');
map.put(']', '[');
map.put('}', '{');
String str = "";
for (int i = 0 ; i < s.length() ; i++) {
char temp = s.charAt(i);
if (temp == '(' || temp == '[' || temp == '{') {
str = str.concat(String.valueOf(temp));
} else {
if (str.length() - 1 < 0 || map.get(temp) != str.charAt(str.length() - 1)) {
return false;
}
str = str.substring(0, str.length() - 1);
}
}
if (str.length() == 0) {
return true;
}
return false;
}
}
反问:
2022.8.16
时长:50min
import java.util.*;
public class Main {
public static void main(String[] args) {
Map<String, String> map = new HashMap<>();
map.put("a", "a1");
map.put("b", "b1");
map.put("c", "c1");
// 1.set
Set<String> set = map.keySet();
for (String k: set) {
System.out.print(k + " " + map.get(k));
}
// 2.Set>
Set<Map.Entry<String, String>> entrySet = map.entrySet();
for (Map.Entry<String, String> entry: entrySet) {
System.out.print(entry.getKey() + "," + entry.getValue());
}
}
import java.util.*;
public class Main {
public static void main(String[] args) {
List<Integer> list1 = new ArrayList<>();
List<Integer> list2 = new ArrayList<>();
list1.add(3);
list1.add(2);
list1.add(1);
list2.add(1);
list2.add(2);
list2.add(4);
// Collections
Set<Integer> integerSet = new HashSet<>();
integerSet.addAll(list1);
integerSet.addAll(list2);
List<Integer> newList = new ArrayList<Integer>(integerSet);
Collections.sort(newList);
for (Integer i: newList) {
System.out.print(i + " ");
}
}
}
反问:
2022.8.18
时长:40min
反问: