Java最重要要掌握的技能_java程序员应该掌握的技能

这是看了一篇大神说的java程序员应该会些什么的文章,这里只是把应该掌握的技能部分列了出来。

static、final、transient、volatile关键字,内部类,泛型等

static最需要记住的一点就是类属性中被static修饰的变量,会被作为GC的root根节点。作为根节点就意味着,这一类变量是基本上不会被回收的,因此static很容易引入内存泄露的风险。static会将所应用的属性,方法以及内部类直接产生引用关系,而并非与类的实例,这是为什么可以使用类名.方法名就能引用的原因。如果没用static修饰内部类,那么声明内部类的时候就需要先生命外部类实例,在由外部类生命一个内部类实例。

volatile关键字,重点就是 “可见性” 。要知道,可见性到底是什么意思,弄明白这个需要了解真么叫主存和工作内存。还有volatile并不保证同步。

重要的是知道原理,不是只是会用。

java运行时环境

java运行时环境就是jre,本质是JVM。首先知道JVM与Hotspot的关系。JVM更多指的是JVM规范,而Hotspot是JVM的一种实现。可把JVM规范当做接口,Hotspot当做一种实现。这样好理解一点。

JVM最重要的三个部分:内存划分、class加载机制、GC策略

这里所说的内存划分,其实指的是Hotspot的划分方式,并不是JVM规范划分方式。

Hotspot内存划分简单说分为三个部分:Young Generation(年轻代),Old Generation(年老代)、Perm Generation(永久代)。

其中年轻代又分为三个部分(Eden,From,To)其中From和To统称为Servivor Spaces(幸存区)

classloader加载机制,可以结合tomcat学习,了解清除tomcat的classloader机制,看tomcat如何保证各个APP之间的类隔离的。

GC自己找地方看

并发只是与concurrent包

关于并发,最重要的概念要搞清楚:原子性、可见性。

concurrent包中ConcurrentHashMap和普通的同步HashMap之间的区别。这个问题需要知道两个知识,一个是HashMap的数据结构,一个是锁分段的技术。

concurrent包中有一个AbstractQueuedSynchronizer几乎所有的concurrent包内的并发工具类都是基于这个类,把这个研究透。

ReentrantLock和synchronized关键字的区别,synchronized由于是底层JVM实现的互斥,因此效率更高一些,而ReentrantLock的功能更多。

并发是java程序员进阶的重要部分。。。。。。

设计模式和反射

设计模式:http://www.cnblogs.com/zuoxiaolong/category/509144.html

反射:reflect包

文件IO,NIO、网络IO以及网络协议

tomcat有多种协议的实现、其中包扩了BIO、NIO、和APR,这三者一定非常他们的 区别,这个可以在connector的protocol属性配置

网络IO就是net包里的东西

网络协议也要理解。TCP:重试机制,三次握手,TCP和UDP的区别

spring、mybatis框架

Linux服务器:文件系统、网络、IO

数据库优化

消息服务:rabbitMQ、activeMQ、rocketMQ。精通原理

缓存服务:memcached,redis

负载均衡

数据结构与算法

计算机操作系统

计算机网络

熟练使用一种脚本语言:如:Python

gitlub和博客

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值