一文告诉你 Java 后端求职到底要学什么
【💦 泼冷水环节】
首先问问你自己:
❓ 你有高学历吗?
❓ 你是科班吗?
❓ 你有时间去实习吗?
❓ 你能一直坚持受苦吗?
如果上述答案都是“❌ 否”,建议换个赛道。
如果觉得自己能卷,也要接受一个事实:
📅 现在是12月份,秋招已经结尾了,我认识的好几个在大厂实习过的还是 0 Offer(当然太小的公司他们也不投)。
⚠️ 现在不是时代红利期了,这个要注意,选了这个方向,注定要被打击的(当然学历高,能力很强的大佬除外)。
【🎯 互联网大厂考试问什么?】
📚 八股
💼 实习
🛠️ 项目
🎨 场景设计(很重要,基本决定池子能不能泡得出来,场景题回答不好可能可以进池子,但很难泡得出来,因为竞争对手答出来了)
🧩 智力题(腾讯、字节这些会问)
⚙️ 算法手撕
【🚀 小白入门技术学习】
可以直接找黑马程序员这些视频来看
1️⃣ JavaSE
2️⃣ MySQL
3️⃣ Spring三件套:Spring、Mybatis、SpringMVC
4️⃣ SpringBoot
5️⃣ Redis
6️⃣ MQ:推荐RocketMQ/Kafka
7️⃣ SpringCloud:可以不学,属于加分项,学了这个,项目可以加上很多分布式亮点,例如分布式锁、分布式ID、分布式事务等等
【📁 项目相关】
学习完上面的基础知识,就可以做简历的项目了(当然上面的教程一般也会用一些简单项目来演示)
🔹 选什么项目?
- 最好做 ToC 项目(结合AI更好,因为现在AI很重要)
- 如果前面ToC项目已经带了比较多AI,第二个项目可以做轮子项目,比如动态线程池、RPC、手撕Spring…
⚠️ 注意:
- 项目新不新颖没那么重要,重要的是项目一定要有自己的思考和亮点,用一个方案的时候,知道为什么要用这个方案,是否契合场景,为啥不用其他方案,要注重实际成本,不要过度设计,对于一个本身没几个QPS的系统,你用一堆分布式设计,没必要,只会徒增成本
- 项目不是功能越多越好,而是越深、越体现思考越好。有人写一堆功能,全是增删改查,这种没有意义
- 多比较不同方案,例如性能有多少提升、是否能保证数据一致性、节省多少内存
- 多拷打自己的项目,请有经验的人、AI出题,看别人面经都行。比如你写个JWT实现登录,我可以问你 JWT无状态是什么意思,优缺点,还有哪些登录认证方式、JWT令牌如何撤销、长短令牌机制、管理员如何踢人、如何限制单个账号的设备登录数、令牌安全性如何保证
【⚙️ 算法相关】
📊 数据结构与算法:数组、链表、栈、队列、二叉树、B树/B+树、红黑树、堆、动态规划、排序算法(学个归并排序、快速排序吧)。
💻 刷题建议:
- 直接刷题,遇到不会的知识点,可以让AI教教你。
- 代码随想录打基础(时间紧直接跳过)
- hot100(熟读并背诵,来回刷,来回刷,刷到后面看到数据就知道答案是什么就可)
- 还有精力就继续刷codetop前200,基本面试手撕都足以应付了,笔试手撕还是有难度的
⏳ 建议学完Java就开始每天学习一点算法,比如每天学三十分钟/一小时
【🧠 面试重点知识】
有时间就系统学,没时间就直接看八股,大概需要花 2~3 个月
【🧩 场景题】
可以前面的知识都搞定了,再来攻关这部分。一般一面问八股,二面三面喜欢问场景设计,怎么准备?
1️⃣ 收集别人面经的场景题,有的场景题经常会被问的,比如10G数据,怎么在500M内存计算机里面排序、去重、取最大数、中位数……
2️⃣ 归类总结题型:功能设计(如扫描登录怎么实现)、高并发设计(演唱会抢票系统设计)、大数据量、高可用性、问题排查场景
3️⃣ 对每种问题总结属于自己的答案,也可以参考别人的答案
【🔧 后端程序员傍身小知识】
🔹 Maven
▸ 知道怎么安装、导入依赖、打jar包就可以
▸ 基础的项目管理与构建工具
🔹 Linux
▸ 掌握基础命令
▸ 如查看内存占用、CPU、进程、端口占用等
▸ 服务器操作必备技能
🔹 Git 💡 比较重要
▸ 建议在开始项目前就学习
▸ 用于管理代码版本更新
▸ 团队协作与代码管理的核心工具
▸ 工作必备知识
#牛客解忧铺##秋招#