阿里架构师谈:工作三年的Java程序员应该达到什么水平?

2024-05-09 15:08

本文主要是介绍阿里架构师谈:工作三年的Java程序员应该达到什么水平?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近,又是跳槽换工作的黄金季节,也就是大家俗称的「金九银十」。

有的读者可能会问为什么呢?那我就来给你说道说道。

对于大公司而言,会在如下两个时间节点之前进行对员工一年的绩效考核和奖金发放。

以12月31日为财年的,1月份考核统计,2月份发奖金,3-4月份面试/跳槽。

以6月30日为财年的,7月份考核,8月份发奖金,9-10月份面试/跳槽。

因此,这两个时间段是大多数程序员跳槽的高峰期。但是,无论如何建议大家做好自己的职业规划,不要为了跳槽而跳槽,眼光要放长远一点,千万不要裸辞。。。

好了,言归正传,本文主要回答一个读者的提问。

问题:一般工作的三年的程序员应该达到什么样的水平才算合格呢?

下文的答案是我工作这些年的一点经验分享,希望对你跳槽有所帮助。

对于工作三年的 Java 程序员来说,不一定非得要你「举一反三」,你应该要达到「举一反一」的效果。

我之前就跟我的很多读者说过,大多数人干了三年还抵不上别人干一年,这也就是大多数 Java 程序员所面临的瓶颈 —— 「高不成低不就」。

我觉得要突破这个瓶颈你可以从如下三个方面来提升。

一、工具

你一定要熟练一款操作系统,一款 Java 开发工具,一款浏览器,Bug 分析工具,性能分析工具等。

对于操作系统而言,我建议你用 Mac ,因为它是类 Unix 系统,方便你熟悉 Linux 命令,因为你所开发的 Java 项目,95% 以上都是跑在 Linux 上面,这样面试的时候,也不至于面试官问你几个常见的命令而不知所云。

对于 Java 开发工具而言,我建议使用 IDEA,原因很简单,想比于其它工具而言,它会更懂你。

对于浏览器而言,毫无争议的建议你用 Chrome。

对于 bug 分析工具而言,太多了,有 Java 自带的jdb、jinfo、jps、jstack、jmap、jstat、jconsole、jvisualvm 等,也有商用 JProfiler,还有动态跟踪的btrace 等。

对于性能分析工具,我建议你掌握两款 ab 和 jmeter 足矣。

二、Java 基础

作为一名 Java 程序员,你一定要对 Java 语言掌握的非常熟悉,熟悉到常见类的用法,在什么样的环境应该用什么样的类,以及要明白为什么要这么用。

比如 Java 的数据结构,字符串、数组、List、Set、Map等。你要明白这些结构的用法,那些适合用在并发的环境,那些又不适合,如果误用了会产生什么样的后果。

并发也你必须了解的,其实并发说白了,就是 Java 用来解决内存的可见性和程序执行的可见性。即 volatile 关键字、synchronize 关键字,以及在它们基础上衍生出来的 AQS 和原子变量类,又在它们之上继续产生的 Lock、同步器、阻塞队列、Executor、并发容器,以及一些开源的调度框架 spring task、quartz。

JVM 常问,如果你经常写业务,会很少接触,但是面试官会常问,所以你需要掌握,比如它的内存模型,每个区该干什么?一个字节码类的结构是怎么样的?有哪些常见的回收器,以及那些常见的垃圾收集算法?一个类的加载过程又是怎样的?JVM做了那些编译优化?有那些语法糖?等等

最近,JDK 11 马上又要发布了,那么 JDK8 你应该要了解一下吧,它的那些新特性你用过没?

上面的这些就是所谓的基础,你可以试着反问一下自己是不是应该掌握呢?

三、熟悉一个领域

既然工作了三年,那么大大小小的项目,相信你肯定做了不少,那么你至少应该擅长一个领域。比如缓存、数据库、分布式框架、一些常见的组件。

对于缓存而言,你要理解 memchache 和 redis 中的一个,比如什么是一致性hash?redis 线上你遇到过的什么问题,你又是怎么解决的?

对于数据库而言,大多数互联网公司都是用的 MySQL,因此,你需要对它特别熟悉,面试官的一个查询需求,你能快速的转换成 SQL 语句。什么是最左原则?怎么建立索引才能提高命中率?如果出现慢查询又该怎么分析问题?每种存储引擎的数据结构又是怎么样的?什么情况下会出现死锁?事务又是怎么回事?等等

对于分布式框架而言,有的用 dubbo,有的用 spring cloud,无论你用什么,它们的最核心的东西基本一样,都有注册中心、服务端、消费端以及监控中心。因此,你要把它们理解清楚。

一些常见的组件,比如 Mybatis 、Guava、Common包等等,你得知道它的常见用法,以及这些用法的背后实现原理。

总结一下,对于三年的 Java 程序员而言,一和二必须掌握,三选择一个感兴趣的方向深入研究。

无论你工作多少年,我希望你永远记住『我是一名计算机工程师,不是打字员』。。。

 

这篇关于阿里架构师谈:工作三年的Java程序员应该达到什么水平?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/973726

相关文章

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

LiteFlow轻量级工作流引擎使用示例详解

《LiteFlow轻量级工作流引擎使用示例详解》:本文主要介绍LiteFlow是一个灵活、简洁且轻量的工作流引擎,适合用于中小型项目和微服务架构中的流程编排,本文给大家介绍LiteFlow轻量级工... 目录1. LiteFlow 主要特点2. 工作流定义方式3. LiteFlow 流程示例4. LiteF

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

java中long的一些常见用法

《java中long的一些常见用法》在Java中,long是一种基本数据类型,用于表示长整型数值,接下来通过本文给大家介绍java中long的一些常见用法,感兴趣的朋友一起看看吧... 在Java中,long是一种基本数据类型,用于表示长整型数值。它的取值范围比int更大,从-922337203685477

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程

《SpringBoot集成LiteFlow实现轻量级工作流引擎的详细过程》LiteFlow是一款专注于逻辑驱动流程编排的轻量级框架,它以组件化方式快速构建和执行业务流程,有效解耦复杂业务逻辑,下面给大... 目录一、基础概念1.1 组件(Component)1.2 规则(Rule)1.3 上下文(Conte

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过