去年年底从华为裸辞(莽撞了,没想到今年春天寒风凛冽),开始重新找工作。休息了一个月,复习了大概一个月的时间,开始找工作。(目前拿到了两个offer,推掉了其中一个,就不说是哪几家了)
先说结论吧。
开发过程当中的技术细节一定要好好复习下,八股和开发过程应该并重。具体的面试题的话,其实都在我下面的个人知识树技术点里面。
最重要的一点是,珍惜每一次面试机会,现在客户端岗位已经很少了,不像之前一样有很多岗位供我们挑选。一定要先复习好再面试!!!
面试技巧总结:
1.如果问到一个是与否的问题,咱们可以先说结论,然后再梳理导致这个结论的原因,不然面试官可能没有心情听你巴拉巴拉讲下去。
2.主管面和技术面侧重的点可能不一样。咱们自我介绍前可以先和面试官沟通一下,问问是侧重介绍技术还是侧重介绍业务,又或者是两者都要。介绍技术没啥好说的,大概就是介绍下用了什么技术(如果有技术选型的背景的话,也可以聊聊不用别的技术,用这个技术的原因),这个技术背后的原理。如果是介绍业务的话,可以介绍下业务背景,业务的作用和收益。
3.面试问到一个你可能思考不多的问题,不要直接回答没有用过。要梳理下思路,把你知道的,或者你推理的逻辑跟面试官好好讲讲。 感觉我有些面试就是挂在了这些点上,可能没有思考过,就直接说自己没用过,然后会给技术官一个没有深入思考理解的印象,非常减分。
复习重点:
1.项目技术点,例如用到了哪些三方SDK,原理是什么,尤其是一些通用性比较强的SDK,例如:retrofit、glide等
2.一些常见技术点八股,例如:RecycleView、handle等
3.面试者自己的特长技术点,例如:framework相关service的理解、音视频编解码原理、机器学习相关概念等等
4.算法,可以刷刷不同算法类型的题目
面试经历
百度到了三面,挂了! 感觉主要原因是三面没有get到面试官的点。 这个三面面试官可能主要考察对项目业务的理解,然后我巴拉巴拉一堆技术点。今天早上接到百度另外一个部门的面试邀约电话,等面中...
B站三面挂,反馈是认可从0到1的能力,但是技术细节掌握不够。这个确实是过去的开发细节我没有答好,很多细节上面没有复习,光复习八股了。
腾讯:一面挂,这个是因为在复习之前莽撞的投下了,相当于裸面了。
传音:二面,等消息
吉利:算法面和技术面都通过了,结果被HR卡了,因为之前有两家公司就职经历比较短...
拼多多:到面试的时候才收到HR面试通知,完全没有准备。一面挂,也是细节上面答得不好,算法深度优先算法没有写出来,后面面试结束花了半小时写出来了。算法:非完全二叉树最底层最右侧节点的路径。
static class TreeNode{
public int value;
public TreeNode left;
public TreeNode right;
public TreeNode(int value, TreeNode left, TreeNode right){
this.value = value;
this.left = left;
this.right = right;
}
}
public static Stack<TreeNode> rightNodeStack = new Stack<>();
/**
* 算法程序入口
* @param root
* @return
*/
public static List<Integer> nodeTree(TreeNode root){
List<Integer> rightNodes = new ArrayList<>();
List<TreeNode> levelNodes = new ArrayList<>();
if (root.left != null){
levelNodes.add(root.left);
}
if (root.right != null){
levelNodes.add(root.right);
}
handleNode(levelNodes);
rightNodeStack.push(root);
while (!rightNodeStack.isEmpty()){
rightNodes.add(rightNodeStack.pop().value);
}
return rightNodes;
}
public static TreeNode handleNode(List<TreeNode> levelNodes){
List<TreeNode> levelChildNodes = new ArrayList<>();
for (TreeNode item: levelNodes){
if (item.left != null){
levelChildNodes.add(item.left);
}
if (item.right != null){
levelChildNodes.add(item.right);
}
}
if (levelChildNodes.size() == 0){
rightNodeStack.push(levelNodes.get(levelNodes.size() - 1));
return levelNodes.get(levelNodes.size() - 1);
}else {
TreeNode childNode = handleNode(levelChildNodes);
for (TreeNode parentNode: levelNodes){
if (parentNode.left == childNode || parentNode.right == childNode){
rightNodeStack.push(parentNode);
return parentNode;
}
}
return null;
}
}
自己源码阅读输出文档:
面试的时候,面试官问我在工作和学习过程中有没有什么输出。
想了下,个人知识树应该也算是输出的一部分吧。
个人知识树链接:https://kdocs.cn/l/cesOXINnAElm,请大佬们评阅!