360行,行行转JAVA,转行十个月拿下快手offer月薪
楼主大学学的是电子专业只接触过C++,偏向于硬件方面,大三开始接触因为学业只是初步了解,假期开始系统的去学,虽然已经放弃了自己的专业,但是还是要拿到学位,相当于同时修两门那段时间还是比较累的
从实习到年前一直在一家公司,这次感觉自己准备的差不多了打算跳槽的,之前总以为需要刷很多题,一直没时间刷就一直没行动。幸好之前公司的一个前辈,他跟我传授经验,让我先面小公司积累经验,之后再去面大公司。我受他的鼓舞,终于决定了在年后踏上面试之路。
事实证明“练手”真的很有必要。我一共面过阿里、蚂蚁、字节、Shopee、OPPO、华为、美团、快手。一开始我连自我介绍都不会,所以前面面的阿里、蚂蚁、字节、Shopee 都跪了;中间面的 OPPO、华为面了一半失去音讯;后面面的美团、快手、猿辅导、腾讯都拿到了 offer。
这些公司每家偏重点不同,难度也不同,有的中规中矩,有的挖尽细节。事后总结了一下,大体都能分为下面列举的 7 个问题,列出来跟大家分享一下。
下面也没分一二三四面,没分公司,就是提取了共性。
远程面试,视频接通后,面试官可能会简单介绍下自己,然后就直接让你做一个自我介绍,这个没有例外。
我一开始心里想这不都是简历上写着的么?后来感觉可能是考察你的表达能力吧。这个时候说说姓名、学校、专业、毕业时间、工作经历、主要项目、技术栈,应该就差不多了。
说完之后,有的面试官会认真听,并且就你说的找他感兴趣的问你,当然也有的面试官就走个过场,你说完他就不管了,直接问下一步。
工作经历通常说到工作经历的时候,会问你:
毕业第一份工作为什么选择了那里?为什么看机会?上次换工作为什么?有了解过我们部门做什么的么?感兴趣么?工作这段时间,主要的收获是什么?最好别老抱怨之前的公司,可以说说自己的规划之类的。
我在被问到这个问题的时候通常是一头懵逼,因为我之前没有好好想过,大家可以准备一下。
未来的规划(城市)技术上的追求长期方向(行业)基础知识基础知识这块是跟你简历上提到的技术栈相关的,每个人不一定相同,但 Redis 和 Kafka 都是没有被错过的。这一块就是考察你掌握是深度了,不一定全都要了解到底层,每家要求不一样。
下面是我自己学习的时候整理了的一些面试中出现的高频问题和知识点,有需要的朋友可以转发一下(帮助更多需要的人)然后私信我【学习】免费分享给大家
JAVA基础int float short double long char 占字节数?int 范围?float 范围?hashcode 和 equals 的关系深拷贝、浅拷贝区别java 异常体系?RuntimeException Exception Error 的区别,举常见的例子lambda 表达式中使用外部变量,为什么要 final?关于Java基础的一些核心面试整理
集合集合这块关注一下 1.8 的实现吧,和 1.7 相比变化了很多
Collection 有什么子接口、有哪些具体的实现简单介绍下 ArrayList 怎么实现,加操作、取值操作,什么时候扩容?讲一下 hashMap 原理。hashMap 可以并发读么?并发写会有什么问题?讲一下 concurrentHashMap 原理。头插法还是尾插法?扩容怎么做?堆是怎么存储的,插入是在哪里?集合在迭代的过程中,插入或删除数据会怎样?并发线程 进程和线程的区别?并行和并发的区别?了解协程么? 进程间如何通信:进程 A 想读取进程 B 的主存怎么办?线程间通信? 线程的生命周期有哪些状态?怎么转换? wait 和 sleep 有什么区别?什么情况下会用到 sleep? 怎么停止线程? 怎么控制多个线程按序执行?线程池 会用到线程池么?怎么使用的?用什么实现的? 常用的线程池有哪些?用的哪个线程池?什么情况下怎么选择? ThreadPoolExecutor 有什么参数?各有什么作用?拒绝策略? 一个任务从被提交到被执行,线程池做了哪些工作?锁 讲一下锁,有哪些锁,有什么区别,怎么实现的? ReentrantLock 应用场景 死锁条件AQS 了解 AQS 么?讲讲底层实现原理 AQS 有那些实现? 讲讲 AtomicInteger 的底层实现volatile 关键字有什么用?怎么理解可见性,一般什么场景去用可见性讲一下 threadLocal 原理,threadLocal 是存在 jvm 内存哪一块的IOIO 这块我不熟,没有多讲
了解 NIO 么?讲讲NIO 与 BIO 有什么区别?了解 Netty 原理么JVM基本都会问时间复杂度
有哪些常用排序算法?手写快排,快排时间复杂度是多少?快排算法是不是稳定的?什么是稳定性?给定一个字母组成的字符串,找出不含有重复字符的最长子串的长度。9 个硬币中有一个劣币,用天平秤,最坏几次?深度优先,广度优先数字转中文括号匹配,时间复杂度,空间复杂度单向链表的归并排序链表做加法1g 大小文件,里面每行是最大 16k 的单词,限制内存 1m,统计单词频率最多的 100 个单词手写 100 位带小数的大数字的减法全排列。进阶:给数组长度 n,求第 k 行的排列注意注意:需要小编整理的MySQL+Java+Redis+算法+网络+Linux等面试答案、学习笔记、思维脑图(xmind)的朋友可以私信关键词 “学习”免费领取,小编会一一回复大家~
补充一下 offer 情况,最后拿到了美团基础架构、快手主 app、猿辅导斑马、腾讯 csig 的 offer。面试前的“练手”还是很重要的,前期“裸面”浪费了阿里、蚂蚁、字节、Shopee 的面试机会。所有开始面试之前一定要准备好啊,不然也是耽搁面试官和自己的时间。