掌握java基础,熟悉常用类库。理解javaweb中的servlet,jsp,并了解常用的框架对java web的封装原理,能够借助框架完成增删改查功能。理解数据库在web开发中的地位。 初级—中阶
理解java中较为高级的特性,如反射,动态代理,JVM,内存模型,多线程等等。熟练使用框架,对框架中遇到的bug,能够借助日志和搜索引擎分析出问题的原因。在团队中,能够独立完成普通后台业务功能的开发。了解数据库的高级特性,如索引,存储引擎等等。 初级—高阶
理解java分布式架构,微服务架构(如rpc框架dubbo,motan,或springcloud一类)了解其与集中式架构的区别,并能保证分布式代码质量。熟练使用各个中间件如redis,mq,zookeeper等等,并了解其工作原理和使用场景。能够在中级或高级程序员的带领之下,完成非核心功能的研发。能够关注开源,并且具有阅读源码的能力。 中级
初级高阶已经很厉害了,但是往往缺乏的是一些项目经验,所以在我这里还是初级。脱离初级程序员不仅仅需要技术方面的支撑,还需要具备一定的项目开发经验(3年之上一线互联网产品研发经验),拥有线上bug的处理能力,JVM调有能力,以及完成核心业务功能的开发。并且带领团队的新人,能够按能力分配任务。(本想把初级高阶分为中级初阶,但我还是觉得中级必备的水平是线上解决bug的能力) 高级
团队的核心人物,把控整个项目的质量,包括代码漏洞和规范问题。具有5年以上项目开发经验,2年以上架构搭建的经验,能够根据业务选择不同的架构类型;根据团队组成,分配不同的任务。具有将自己的知识分享出去的能力,带领初级程序员走向中级,中级程序员走向高级的能力。
多线程与高并发
JVM调优案例式实战化指导
一、多线程为什么会有并发问题
为什么多线程同时访问(读写)同个变量,会有并发问题?
- Java 内存模型规定了所有的变量都存储在主内存中,每条线程有自己的工作内存。
- 线程的工作内存中保存了该线程中用到的变量的主内存副本拷贝,线程对变量的所有操作都必须在工作内存中进行,而不能直接读写主内存。
- 线程访问一个变量,首先将变量从主内存拷贝到工作内存,对变量的写操作,不会马上同步到主内存。
- 不同的线程之间也无法直接访问对方工作内存中的变量,线程间变量的传递均需要自己的工作内存和主存之间进行数据同步进行。
Java 内存模型(JMM) 作用于工作内存(本地内存)和主存之间数据同步过程,它规定了如何做数据同步以及什么时候做数据同步,如下图。
三、并发三要素
原子性:在一个操作中,CPU 不可以在中途暂停然后再调度,即不被中断操作,要么执行完成,要么就不执行。
可见性:多个线程访问同一个变量时,一个线程修改了这个变量的值,其他线程能够立即看得到修改的值。
有序性:程序执行的顺序按照代码的先后顺序执行。
推荐: 马士兵2020年最新Java多线程高并发讲解——20年架构师告诉你Java多线程与高并发应该怎么学https://www.bilibili.com/video/BV1xK4y1C7aT
P1马士兵Java多线程与高并发①volatile关键字的字节码原语
https://www.bilibili.com/video/BV1xK4y1C7aT?p=1
P2java多线程与高并发②synchronized与volatile的硬件级实现
https://www.bilibili.com/video/BV1xK4y1C7aT?p=2
P3java多线程与高并发③无锁、偏向锁、轻量级锁、重量级锁升级过程
https://www.bilibili.com/video/BV1xK4y1C7aT?p=3
P4java多线程与高并发④内存屏障的基本概念
https://www.bilibili.com/video/BV1xK4y1C7aT?p=4
P5java多线程与高并发⑤使用线程池的好与不好
https://www.bilibili.com/video/BV1xK4y1C7aT?p=5
P6java多线程与高并发⑥为什么阿里开发手册建议自定义线程池
https://www.bilibili.com/video/BV1xK4y1C7aT?p=6
P7java多线程与高并发⑦自定义线程池的最佳实践
https://www.bilibili.com/video/BV1xK4y1C7aT?p=7
P8java多线程与高并发⑧常见线程池类型与应用场景
https://www.bilibili.com/video/BV1xK4y1C7aT?p=8
P9java多线程与高并发⑨JVM规范如何要求内存屏障
https://www.bilibili.com/video/BV1xK4y1C7aT?p=9