[转帖]java学习从入门到精通(2)
Java Learning Path(三)过程篇
每个人的学习方法是不同的,一个人的方法不见得适合另一个人,我只能是谈自己的学
习方法。因为我学习Java是完全自学的,从来没有问过别人,所以学习的过程基本上完
全是自己摸索出来的。我也不知道这种方法是否是比较好的方法,只能给大家提供一点
参考了。
学习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安装目录下面
jre\lib\rt.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.*;
这些包里面真正用的比较多的类其实很少,只有几个,所以不需要花很多时间。
第六步,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好像目前还没有什么很好的书籍,但是可以通过在网络上面查资料
的方式来学习。
Java Learning Path(四) 方法篇
Java作为一门编程语言,最好的学习方法就是写代码。当你学习一个类以后,你就可以
自己写个简单的例子程序来运行一下,看看有什么结果,然后再多调用几个类的方法,
看看运行结果,这样非常直观的把类给学会了,而且记忆非常深刻。然后不应该满足把
代码调通,你应该想想看如果我不这样写,换个方式,再试试行不行。记得哪个高人说
过学习编程就是个破坏的过程,把书上的例子,自己学习Documentation编写的例子
在运行通过以后,不断的尝试着用不同的方法实现,不断的尝试破坏代码的结构,看看
它会有什么结果。通过这样的方式,你会很彻底的很精通的掌握Java。
举个例子,我们都编过Hello World
public class HelloWorld {
public static void main(String[] args) {
System.out.println("Hello World");
}
}
很多初学者不是很理解为什么main方法一定要这样来定义public static void main
(String[] args),能不能不这样写?包括我刚学习Java的时候也有这样的疑问。想知
道答案吗?很简单,你把main改个名字运行一下,看看报什么错误,然后根据出错信息
进行分析;把main的public取掉,在试试看,报什么错误;static去掉还能不能运行;
不知道main方法是否一定要传一个String[]数组的,把String[]改掉,改成int[],或者
String试试看;不知道是否必须写args参数名称的,也可以把args改成别的名字,看
看运行结果如何。
我当初学习Java的时候就是这样做的,把Hello World程序反复改了七八次,不断运
行,分析运行结果,最后就彻底明白为什么了main方法是这样定义的了。
此外,我对于staic,public,private,Exception,try{ }catch {}finally{}等等
等等一开始都不是很懂,都是把参考书上面的例子运行成功,然后就开始破坏它,不断
的根据自己心里面的疑问来重新改写程序,看看能不能运行,运行出来是个什么样子,
是否可以得到预期的结果。这样虽然比较费时间,不过一个例子程序这样反复破坏几次
之后。我就对这个相关的知识彻底学通了。有时候甚至故意写一些错误的代码来运行,
看看能否得到预期的运行错误。这样对于编程的掌握是及其深刻的。
其中特别值得一提的是JDK有一个非常棒的调试功能,-verbose
java –verbose
javac –verbose 以及其它很多JDK工具都有这个选项
-verbose 可以显示在命令执行的过程中,JVM都依次加载哪里Class,通过这些宝贵
的调试信息,可以帮助我们分析出JVM在执行的过程中都干了些什么。
另外,自己在学习过程中,写的很多的这种破坏例程,应该有意识的分门别类的保存下
来,在工作中积累的典型例程也应该定期整理,日积月累,自己就有了一个代码库了。
遇到类似的问题,到代码库里面 Copy & Paste ,Search & Replace,就好了,极
大提高了开发速度。最理想的情况是把一些通用的例程自己再抽象一层,形成一个通用
的类库,封装好。那么可复用性就更强了。
所以我觉得其实不是特别需要例程的,自己写的破坏例程就是最好的例子,如果你实在
对自己写的代码不放心的话,我强烈推荐你看看JDK基础类库的Java源代码。在JDK安
装目录下面会有一个src.zip,解开来就可以完整的看到整个JDK基础类库,也就是
rt.jar的Java源代码,你可以参考一下Sun是怎么写Java程序的,规范是什么样子的。
我自己在学习Java的类库的时候,当有些地方理解的不是很清楚的时候,或者想更加清
晰的理解运作的细节的时候,往往会打开相应的类的源代码,通过看源代码,所有的问
题都会一扫而空。
Java Learning Path(五)资源篇
1、 http://java.sun.com/ (英文)
Sun的Java网站,是一个应该经常去看的地方。不用多说。
2、http://www-900.ibm.com/developerWorks/cn/
IBM的developerWorks网站,英语好的直接去英文主站点看。这里不但是一个极好的
面向对象的分析设计网站,也是Web Services,Java,Linux极好的网站。强烈推
荐!!!
3、http://www.javaworld.com/ (英文)
关于Java很多新技术的讨论和新闻。想多了解Java的方方面面的应用,这里比较好。
4、http://dev2dev.bea.com.cn/index.jsp
BEA的开发者园地,BEA作为最重要的App Server厂商,有很多独到的技术,在
Weblogic上做开发的朋友不容错过。
5、http://www.huihoo.com/
灰狐动力网站,一个专业的中间件网站,虽然不是专业的Java网站,但是在J2EE企业
应用技术方面有深厚的造诣。
6、http://www.theserverside.com/home/ (英文)
TheServerSide是一个著名的专门面向Java Server端应用的网站。
7、http://www.javaresearch.org/
Java研究组织,有很多优秀的Java方面的文章和教程,特别是在JDO方面的文章比较
丰富。
8、http://www.cnjsp.org/
JSP技术网站,有相当多的Java方面的文章和资源。
9、http://www.jdon.com/
Jdon论坛,是一个个人性质的中文J2EE专业技术论坛,在众多的Java的中文论坛中,
Jdon一个是技术含量非常高,帖子质量非常好的论坛。
10、http://sourceforge.net/
SourgeForge是一个开放源代码软件的大本营,其中也有非常非常丰富的Java的开放
源代码的著名的软件。