闯补惫补学习路径
- 1. 学习 Java 的第一步是安装好 JDK,写一个 Hello World, 其实 JDK 的学习没有那么简单,对于 JDK 有两个问题
是很容易一直困扰 Java 程序员的地方:一个是 CLASSPATH 的问题,其实从原理上来说,是要搞清楚 JRE 的
ClassLoader 是如何加载 Class 的;另一个问题是 package 和 import 问题,如何来寻找类的路径问题。把这两
个问题摸索清楚了,就扫除了学习 Java 和使用 JDK 的最大障碍。推荐看一下王森的《Java 深度历险》,对这两
个问题进行了深入的探讨。
第二步是学习 Java 的语法。Java 的语法是类 C++的,基本上主流的编程语言不是类 C,就是类 C++的,没有
什么新东西,所以语法的学习,大概就是半天的时间足够了。唯一需要注意的是有几个不容易搞清楚的关键字的
用法,public,protected,private,static,什么时候用,为什么要用,怎么用,这可能需要有人来指点一
下,我当初是完全自己琢磨出来的,花了很久的时间。不过后来我看到《Thinking in Java》这本书上面是讲了
这些概念的。
第三步是学习 Java 的面向对象的编程语言的特性的地方。比如继承,构造器,抽象类,接口,方法的多态,重
载,覆盖,Java 的异常处理机制。对于一个没有面向对象语言背景的人来说,我觉得这个过程需要花很长很长时
间,因为学习 Java 之前没有 C++的经验,只有 C 的经验,我是大概花了一个月左右吧,才彻底把这些概念都搞
清楚,把书上面的例子反复的揣摩,修改,尝试,把那几章内容反复的看过来,看过去,看了不下 5 遍,才彻底
领悟了。不过我想如果有 C++经验的话,应该一两天时间足够了。那么在这个过程中,可以多看看《Thinking
in Java》这本书,对面向对象的讲解非常透彻。可惜的是我学习的时候,并没有看到这本书,所以自己花了大量
的时间,通过自己的尝试和揣摩来学会的。
第四步就是开始熟悉 Java 的类库。Java 的基础类库其实就是 JDK 安装目录下面 jrelibrt.jar 这个包。学习基础
类库就是学习 rt.jar。基础类库里面的类非常非常多。据说有 3000 多个,我没有统计过。但是真正对于我们来说
最核心的只有 4 个,分别是
java.lang.*;
java.io.*;
java.util.*;
java.sql.*;
这四个包的学习,每个包的学习都可以写成一本厚厚的教材,而 O'reilly 也确实是这样做的。我觉得如果时间比
较紧,是不可能通过读四本书来学习。我觉得比较好的学习方法是这样的:
首先要通读整个 package 的框架,了解整个 package 的 class,interface,exception 的构成,最好是能够找
到介绍整个包框架的文章。这些专门介绍包的书籍的前几章应该就是这些总体的框架内容介绍。
对包整体框架的把握并不是要熟悉每个类的用法,记住它有哪些属性,方法。想记也记不住的。而是要知道包有
哪些方面的类构成的,这些类的用途是什么,最核心的几个类分别是完成什么功能的。我在给人培训的时候一般
是一次课讲一个包,所以不可能详细的介绍每个类的用法,但是我反复强调,我给你们讲这些包的不是要告诉你
们类的方法是怎么调用的,也不要求你们记住类的方法调用,而是要你们了解,Java 给我们提供了哪些类,每个
类是用在什么场合,当我遇到问题的时候,我知道哪个类,或者哪几个类的组合可以解决我的问题,That'all!,
当我们具体写程序的时候,只要你知道该用哪个类来完成你的工作就足够了。编码的时候,具体的方法调用,是
边写代码,边查 Documentation,所有的东西都在 Documentation 里面,不要求你一定记住,实际你也记不
住 3000 多个类的总共将近 10 万个方法调用。所以对每个包的总体框架的把握就变得极为重要。
第五步,通过上面的学习,如果学的比较扎实的话,就打好了 Java 的基础了,剩下要做的工作是扫清
Documentation 里面除了上面 4 个包之外的其他一些比较有用处的类。相信进展到这一步,Java 的自学能力已
经被培养出来了,可以到了直接学习 Documentation 的水平了。除了要做 GUI 编程之外,JDK 里面其他会有用
处的包是这些:
java.text.*;
java.net.*;
javax.naming.*;
这些包里面真正用的比较多的类其实很少,只有几个,所以不需要花很多时间。
- 2. 第六步,Java Web 编程
Web 编程的核心是 HTTP 协议,HTTP 协议和 Java 无关,如果不熟悉 HTTP 协议的话,虽然也可以学好
Servlet/JSP 编程,但是达不到举一反三,一通百通的境界。所以 HTTP 协议的学习是必备的。如果熟悉了 HTTP
协议的话,又有了 Java 编程的良好的基础,学习 Servlet/JSP 简直易如反掌,我学习 Servlet/JSP 就用了不到
一周的时间,然后就开始用 JSP 来做项目了。
在 Servlet/JSP 的学习中,重头仍然是 Servlet Documentation。Servlet API 最常用的类很少,花比较少的时
间就可以掌握了。把这些类都看一遍,多写几个例子试试。Servlet/JSP 编程本质就是在反复调用这些类来通过
HTTP 协议在 Web Server 和 Brower 之间交谈。另外对 JSP,还需要熟悉几个常用 JSP 的标记,具体的写法记
不住的话,临时查就是了。
此外 Java Web 编程学习的重点要放在 Web Application 的设计模式上,如何进行业务逻辑的分析,并且进行合
理的设计,按照 MVC 设计模式的要求,运用 Servlet 和 JSP 分别完成不同的逻辑层,掌握如何在 Servlet 和 JSP
之间进行流程的控制和数据的共享,以及 Web Application 应该如何配置和部署。
第七步,J2EE 编程
以上的学习过程如果是比较顺利的话,进行到这一步,难度又陡然提高。因为上面的知识内容都是只涉及一个方
面,而像 EJB,JMS,JTA 等核心的 J2EE 规范往往是几种 Java 技术的综合运用的结晶,所以掌握起来难度比较
大。
首先一定要学习好 JNDI,JNDI 是 App Server 定位服务器资源(EJB 组件,Datasouce,JMS)查找方法,如
果对 JNDI 不熟悉的话,EJB,JMS 这些东西几乎学不下去。JNDI 其实就是 javax.naming.*这个包,运用起来
很简单。难点在于服务器资源文件的配置。对于服务器资源文件的配置,就需要看看专门的文档规范了,比如
web.xml 的写法,ejb-jar.xml 的写法等等。针对每种不同的 App Server,还有自己的服务资源配置文件,也
是需要熟悉的。
然后可以学习 JTA,主要是要理解 JTA 对于事务的控制的方法,以及该在什么场合使用 JTA。这里可以简单的举
个例子,我们知道一般情况可以对于一个数据库连接进行事务控制
(conn.setAutoCommit(false),....,conn.commit()),做为一个原子操作,但是假设我的业务需求是要把对两
个不同数据库的操作做为一个原子操作,你能做的到吗?这时候只能用 JTA 了。假设操作过程是先往 A 数据库插
一条记录,然后删除 B 数据库另一个记录,我们自己写代码是控制不了把整个操作做为一个原子操作的。用 JTA
的话,由 App Server 来完成控制。
在学习 EJB 之前要学习对象序列化和 RMI,RMI 是 EJB 的基础。接着学习 JMS 和 EJB,对于 EJB 来说,最关键
是要理解 EJB 是如何通过 RMI 来实现对远端对象的调用的,以及在什么情况下要用到 EJB。
在学习完 EJB,JMS 这些东西之后,你可能会意识到要急不可待学习两个领域的知识,一个是 UML,另一个是
Design Pattern。Java 公司软件的设计非常重视框架(Framework)的设计,一个好的软件框架是软件开发成功
的必要条件。在这个时候,应该开始把学习的重点放在设计模式和框架的学习上,通过学习和实际的编程经验来
掌握 EJB 的设计模式和 J2EE 的核心模式。
J2EE 规范里面,除了 EJB,JMS,JTA,Servlet/JSP,JDBC 之外还有很多很多的公司技术,这里不一一进行介
绍了。
另外还有一个最新领域 Web Services。Web Services 也完全没有任何新东西,它像是一种黏合剂,可以把不
同的服务统一起来提供一个统一的调用接口,作为使用者来说,我只要获得服务提供者给我的 WSDL(对服务的
描述),就够了,我完全不知道服务器提供者提供的服务究竟是 EJB 组件,还是.Net 组件,还是什么 CORBA 组
件,还是其他的什么实现,我也不需要知道。Web Services 最伟大的地方就在于通过统一的服务提供方式和调
用方式,实现了整个 Internet 服务的共享,是一个非常令人激动的技术领域。Web Services 好像目前还没有什
么很好的书籍,但是可以通过在网络上面查资料的方式来学习。