给初学者之一:浅谈java及应用
学java不知不觉也已经三年了,从不知java为何物到现在一个小小的j2ee项目经理。虽说不上此道高手,大概也算有点斤两了吧,每次上网,泡bbs逛论坛,没少去java相关的版面,总体感觉初学者多,高手少,精通的更少。由于我国高等教育制度教材陈旧,加上java自身发展不过十年左右的时间,还有一个很重要的原因就是java这门语言更适合商业应用,所以高校里大部分博士老师们对此语言的了解甚至不比本科生多。在这种环境下,很多人对java感到茫然,不知所措,不懂java能做什么,即便知道了java很有用,也不清楚该从哪里入手,所以就有了 java入门难这一说法。ok,那我们就从java到底能做什么聊起。
最后,如果大家如果在自学遇到困难,想找一个java的学习环境,可以加入我们的java学习圈,点击我加入吧,会节约很多时间,减少很多在学习中遇到的难题。
先说什么是java,java是一种面向对象语言,真正的面向对象,任何函数和变量都以类(class)封装起来。
至于什么是对象什么是类,我就不废话了。关于这两个概念的解释任何一本面向对象语言的教材里面都有。
知道了什么是java,那自然就会对java能干什么感兴趣。在说java能做什么之前,先说java作为一个真正面向对象语言的优点。首先第一个,既然是真正的面向对象,那就要做到彻底的封装。这是java和c++最大的不同,java所有的源码以及编译后的文件都以类的形式存在。java没有所谓的类外部定义,所有的函数(方法)以及变量(属性)都必须在类内部定义。这样就不会出现一个类被切割成这里一块那里一块的情况,c++就可以,不是么?这样做使得整个程序的结构异常清晰,明了。其次第二个,最让人欢呼雀跃的是完全屏蔽了指针,同时引入了垃圾回收机制(GC),任何一个写过c/c++代码的人,都会对内存管理深恶痛绝。因为这使得我们不能把主要精力放在我们关心的事情上,而需要考虑计算机内部的一些事情,作为一个软件工程师,我想没有一个人愿意把大量的时间花在内存管理上,毕竟我们不是电子工程师,此时java的优势体现出来了,它完全屏蔽了内存管理。也就是说,如果你用java写程序,写出来的任何一个程序内存上的开销,都不受你控制。乍一看,似乎你受到了束缚,但实际上不是这样,因为虽然你的程序无法对内存进行管理,降低了一定的速度,但你的程序会非常非常的安全,因为你无法调用一个空指针
而不像以前写c的时候那样,成天因为空指针而担惊受怕。当然,如果你深入了解这一行,就会发现java其实也无法保证程序不去调用空的指针,但是它会在最大程度上避免空指针的调用。这已经很好了,安全,这是java的最突出的优点。第三个,虚拟机跨平台,这是java最大的特点,跨平台,可能所有人都知道windows,但是不是所有人都知道unix和java一样,很多人都不知道unix这种操作系统干什么用,我不想多说unix的应用,这不是主要,但是我要说,大部分小型机,工作站,都跑在unix一族的操作系统上,比如linux/solaris,unix比起windows有一个最显著的特点,稳定,这就好比思科和华为,思科的机器慢但稳定,华为的机器快但不稳定,作为服务器这一端来说,unix在服务器端还是非常有市场的,而且很重要的windows不安全,在ms的宣传中我想所有人都很少看到安全二字,因为windows操作系统针对的是pc用户,pc死机就死机咯,大不了重启,瘟95最经常冒出来的就是蓝屏,在服务器这一端上因为ms没有自己的芯片,所以要做系统有些力不从心啊。扯远了,那么java可以做到在windows上编译
然后在unix上运行,这是c/c++做不到的。那么说到这里,java能做什么逐渐清晰起来。刚才说到了,java程序有一个的特点是安全。这个安全是针对你的系统来说得,系统在跑了java程序之后会特别地稳定,而且还能跨平台,那么很明显,java主要应用于除了windows操作系统以外所有的平台,比如手机,服务器。想想看,如果你写的程序要跑在手机上,而手机有多少款用的是windows?就算有,那如果你用c/c++,是不是要针对每一款手机写一套程序呢?累死,那跨平台的java就不用,做到编译一次,随时运行。同样,在服务器这一端,如果我想给一个网络门户站点,比如sina写一个应用程序,pc的性能肯定无法满足sina这样大站点并发数量的要求,那么它就需要买服务器,那么服务器ms没有市场,而且windows很不安全
那么十之八九会买一个sun/ibm的机器,或者hp,但不管是谁的机器,它装的操作系统也不会是windows,因为windows太不安全了,而且多核的支持太差了。这个有空再说,那么如果你要写一个程序在这样的机器上跑,难道我们就在这个机器上做开发么?当然不可能,一般程序员开发用的都是pc,windows那么该怎么办?写一个程序,然后再拿到服务器上去编译,去调试?肯定不可能,所以我们就希望找到一个语言,编译完生成程序之后,在pc上调试,然后直接移植到服务器上去,那么此时,我们就会毫不犹豫地选择java,因为在跨平台以及安全性来说,java永远是第一选择。ok,
下面说java的缺点
一慢,这其实是一种误区,这就好比goto语句一样,java也抛弃了指针,虽然看上去似乎变慢了,但是在这个两三年硬件性能就能翻番的年代,速度已经不是我们关心的问题了,而且对于企业级的应用来说,没有什么比安全稳定更重要的,换句话说,我们可以忍受慢,但是不能忍受死机和蓝屏。而且越大型的应用,这种慢的劣势体现得越模糊。因为当系统项目越做越大,任何一个环节做不好都可能影响全局的情况下,安全尤其重要,而且就像goto语句一样。这种过分追求速度的主张会给系统开发和纠错以及维护带来无可挽回甚至不可避免的损失,把内存交给计算机去管理吧,这种代价值得。我们做的不是pc游戏,没必要把内存的那一点点消耗当亲爹。
二难看,又是一个误区,很多人甚至拿出java swing控件画出的界面来说,呵呵,其实java不是不能画得好看,IDEA就是java写的IDE,挺漂亮的。但为什么难看呢,是因为swing控件它本身就是unix时代的产物,swing控件贴近unix界面,老外看unix界面其实挺顺眼的,他们就是吃unix饭长大的,而unix又是吃百家饭的,不像ms那么唯利是图,所以不怎么对中国人友好,加上我国又没有公司在做操作系统,所以看上去是不怎么顺眼,其实玩过unix的人都知道,unix对中文的支持一直不怎么好。
给初学者之二:从JDK说起
在知道了java有什么优点,能做什么之后,就该说一下java该如何去学了。在说java如何去学之前,有必要把java的几个大方向做一个简单说明,早在五年前,嗯,应该说是六年前,也就是99年的时候,sun公司做出了一个决定,将java应用平台做一个划分,毕竟在不同领域,语言应用特性是有区别的。针对不同领域内的应用,sun公司可以发布相关高端标准来统一规范代码,这三大块就是J2SE,J2EE以及J2M。这个举措今天看来无疑是非常了不起的,正是由于这次革命性的发展,使java从一种小打小闹游戏性的语言,发展成为今天企业级应用的基础。这里要特别说明一下J2SE J2EE J2ME中2的意思,其实2就是英文单词to的谐音,就是to的意思,而不是second edition,当然java 2本身版本号就是1.2,也有点2nd edition的味道。说点题外的,sun公司发布的java版本很有意思,虽然总是写是1.X但其实外界对这种版的说法也就是X.0,比如java 2,其实就是java 1.2,1.3其实就是3.0,1.4就是4.0,现在所说的5.0其实就是1.5,只是以前我们更习惯叫1.X而已。可能到了5.0以后,就全改叫X.0而不是1.X了,所以以后听到别人说java 5.0,千万别惊讶,其实就是1.5。在这三个J2*E中J2SE是基础,就是java 2的标准版(java 2 standard edition),也就是最基础的java语言部分,无论学什么java技术,J2SE都是必须掌握的,要使用J2SE就必须安装JDK(java development kit)。JDK在sun公司的主页上可以免费下载,下载后需要安装,具体安装流程看教材。JDK包含有五个部分:核心API,集成API,用户界面API,发布技术还有java虚拟机(JVM)。先说运行环境,运行环境最主要要说的就是java虚拟机(JVM)
前面我们说过java是跨平台的语言,那么如何做到跨平台呢?毕竟每种操作系统都是不同的,java的设计者们提出了一个虚拟机的概念,在操作系统之上建立一个统一的平台,这个平台必须实现某些功能以支持程序的运行。如下图:
----------------------------------------------------------------------------------------------------------
| program |
---------------------------------------------------------------------------------------------------------
| JVM |
---------------------------------------------------------------------------------------------------------
| UNIX | Windows | Linux | Solaris |..
----------------------------------------------------------------------------------------------------------
程序员所写的每一个程序都先运行在虚拟机上,所有操作都必须经过虚拟机才能和操作系统交互,这样做不仅统一了所有操作系统,同时也保证了操作系统的安全。要死机的话,死的是虚拟机(JVM)而操作系统并不会受此影响,而我们所说的java运行环境指的主要是JVM,其他的不说了,省略。下面说说JDK(java development kit)的API,其实用JDK来包括运行环境以及开发工具,个人感觉是不恰当的,因为这三个单词仅能说明开发工具,也就是几个标准的API,而没有让人感觉到有运行环境的意思在里面,这是题外。那么什么是API?简单地说就是Application Programming Interface,应用程序编程接口。在java里面,就是一些已经写好了的类打成的包,这又要解释什么是类什么是包了,简单说一下,包就是类的集合,一个包包含零个或多个类,嗯,具体的可以去看书,这些类是java的基础类,常用的类,可以简单理解成java的工具集。最后说一下JDK的发布技术,其实按我的理解,讲白了就是编译器,将.java文件转换成.class文件的一种技术。这三部分组成了JDK,有了JDK,就可以开发出J2SE应用软件了,最原始的只要用一个记事本写几行代码就可以了,但一般来说我们会使用效果比较好的开发工具,也就是IDE。在J2SE这一块,特别推荐JCreator这款IDE sun公司的产品,与JDK结合得几乎是天衣无缝,非常适合初学者使用。
教材方面中文的推荐电子工业出版社出版的《java教程》初级与高级篇各一本;还有就是《21天学通java》虽然有人说21天系列是烂书,但个人感觉对于j2se,这本书翻译得已经很不错了,基本没有什么语法错误,语句也很通顺;最后要说的就是《thinking in java》,这本书自然很经典,说得比较细,只是我觉得不太适合初学者,其实也不难,初学者直接看也不成问题,但个人感觉还是找本教材也就是前面推荐的两款来看比较好。基本概念的理解还是用教材的,毕竟thinking in java有的版本翻译得很烂,而且个人建议还是看原版比较好。当然这几本都看最好了,但如果没时间,至少精读其中一本,然后再看其他两本就可以,其实三本书内容也差不多,但看问题的角度方式以及面向的读者也都不同,嗯,怎么说呢,找适合自己的吧。最后要说的是,由于虚拟机的存在,J2SE的大多数软件的使用会比一般桌面软件慢一些,效果不尽如人意,现在大概只有swing控件还在使用吧,其它没怎么听说。J2EE&J2ME,这是java应用的重中之重,如果想拿高薪,最好把J2EE学好,记得以前在csdn上看过一个调查,月薪上万的程序员主要从事哪方面的工作,十个中有八个是做J2EE的,其他两个一个做J2ME,还有一个做嵌入式,也许有些夸张,但也从某一方面说明J2EE人才的稀缺以及应用的广泛。所以如果想学java,只精通j2se是永远不够的,至少还需要时间去了解其它两个J2*E。
给初学者之三:java企业级应用之硬件篇
总算讲到企业级应用了,内容开始逐渐有趣起来。java企业级应用分为硬件篇和软件篇,重点在软件,硬件是外延,严格地说与java没有必然联系。但是,由于java是网络语言,不了解硬件的一些基础知识,软件知道再多也没什么用,不要上了战场还不知道为什么而打仗。硬件是软件的基础,在这个前提下,有必要专门花一点点篇幅来聊一下硬件。硬件,简单地说就是我们实际生活中看得见摸得着的东西,也就是那些冰冷的机器,比如服务器,个人电脑还有网络交换机,路由器等等。那么先抛开网络设备不谈,先来说说计算机电脑的历史。在很早很早以前,人类创造了第一台电脑,那时候的电脑只是一台用来计算的机器,无比大,无比重,无比傻,除了算其它屁事不会做,没有所谓的人工智能与计算机网络。但是总算是诞生了,虽然以今天的眼光去看那时候的机器巨傻无比,只配叫做计算器而不是电脑,没有逻辑思维能力,只会死算,但千里之行,始于足下,反正是造出来了 。然后随着时间的推移,制造业发展发展发展,电脑性能逐渐得到提升,速度快了起来,成本也逐渐低了下来。于是人们造出了第二台,第三台,第四台,第五台……第n台计算机,人们就造出了无数台计算机并使其成为一种产品,逐渐应用于许多复杂计算领域,不仅仅是科研,许多生产领域也开始出现计算机的影子。然后又随着时间的推移,人们发现不可能把所有的计算机都做成一个样子,因为各行各业对计算机性能的要求各不相同,于是开始把计算机划分档次,最简单地是按照计算机的大小划分就是教科书上写的大型机,中型机,小型机//个人感觉这样分纯粹扯淡,还以为是小孩子玩球,分为大球,中球和小球。但是不管怎样,计算机不再是千篇一律一个样子了。按照性能的不同,在不同领域,出现了满足符合不同要求的计算机。几乎在同时,人们也开始考虑计算机之间通讯问题。人们开始考虑将不同的计算机连接起来,于是网线出现了,网络出现了。又随着网络的发展,出现了一下专门为了寻址而存在的机器,这就是路由器和交换机。然后又出现了一些公益性的组织或团体
他们制定了一系列的标准来规范以及管理我们的网络于是3w出现了,计算机的网络时代来临了。嗯,说到这里,计算机发展到今天的历史大概说完了。我们来详细说说网络时代的计算机以及各个硬件供应商之间的关系。前面说到了,计算机分为大型机,中型机和小型机……但是现在市场上没有人这样分,要是出去买机器,对硬件供应商说,我要买一款中型机,或者说,我要买一款小型机,硬件供应商肯定会问问题
他们会问你买机器干什么用的?科学计算啊还是居家用,是作服务器啊还是图形设计,但不管怎样,简单地说大中小型机已经没有什么意义了,我们按照使用范畴来划分。简单划分为服务器,工作站还有微机,服务器(server)。服务器涵盖了几乎所有的大型机以及大部分中型机甚至一些小型机,用通俗点话说24小时不间断运行提供服务的机器。比如卖飞机票(中航信),比如酒店预定(携程),比如提供门户站点相关服务(sina),比如电子商务(ebay,amazon,阿里巴巴),这些服务对机器都有一些特定的要求,尤其强调安全和稳定。工作站(workstation),工作站其实是图形工作站的简称,说白了,就是某种功能极其强大的计算机,用于特定领域,比如工程设计,动画制作,科学研究等。个人电脑/微机(pc)
计算机网络的最末端,这个应该不用我说太多了,网络时代的pc已经普及到千家万户。说完了分类,我们就来说说各个硬件供应商,首先是服务器还有工作站,这两类硬件供应商主要是以下三家Sun,IBM还有HP(惠普)。然后是PC,以前IBM还有PC事业部,现在被联想吞并了(蛇吞象),现在国际市场上有联想和DELL(戴尔),目前戴尔还是国际老大,还有HP康柏。然后是网络,也就是路由器和交换机,这块市场嘛,Cisco(思科)Brocade(博科)还有McDATA三足鼎立。内核(CPU),PC内核主要是AMD和Intel,前者最近与Sun公司合作,Sun也有一部分单双核服务器用的是AMD的。服务器与工作站内核,这一块与硬件厂商绑定,还是Sun,IBM,HP三家自己生产。题外,在一些大型主机应用市场,比如卖飞机票,德国的汉莎,中国的中航信,香港的国泰用的都是尤利(美国的公司,英文名我忘了),其它用的是IBM的机器,现在能做大型机的感觉似乎只有IBM可以,尤利已经快倒了,技术太落后了,现在他们的系统还是fortran写的,连c都不支持。要特别说明的是,一个超大型主机然后多个小终端/pc的结构现在越来越没市场了。将来的趋势是用一整个包含多个服务器的分布式操作系统来取代这些大型主机。因为大型主机更新换代极其困难,一旦数据量超过了主机的处理能力,那么就要换主机,这个成本是极大的,但是如果用分布式操作系统,那就只需要增加小服务器就行了。硬件就大概说到这里,与大多数人没什么关系,因为大多数人压根不可能进入这些硬件领域,除非做销售。说了这么多,只是为了给软件部分打基础而已。//做嵌入式的除外。
给初学者之四:java企业级应用之软件篇
嗯,说过了硬件就该是软件了,这篇是这个系列的重中之重。首先我们来说说什么是软件,统一一下概念。
所谓软件通俗地说就是一套计算机程序,实现了某些功能的计算机程序。
在很早很早以前,一台计算机的软件是不分层次结构的。一台计算机只有一个系统,这个系统既是操作系统又是应用软件,与硬件紧密绑定。后来经过许多年的发展发展发展,人们把一些与硬件紧密相连的又经常用到必不可少的功能做到一套程序中去,这一套程序就被人们称做操作系统。另外一些可有可无的,不同工作适应不同环境的功能封装到另外一套程序中去,而这一系列程序被人们称作应用软件。如下图:
-------------------------------------------
|应用软件:falshgat/IE/realplayer/winamp..|
-------------------------------------------
|操作系统:UNIX/Windows/Linux/Solaris... |
-------------------------------------------
前一篇我们知道,硬件分为服务器工作站与pc,其实无论哪种硬件的软件,都有操作系统与应用软件。 ok,那下面我们来谈应用软件。在现在企业级应用中,我们的应用软件一般分为三层,三层分别是表示层,业务逻辑层,数据持久层。
------------------------------
|表示层|业务逻辑层|数据持久层|
------------------------------
1.表示层
这一层一般在客户端pc机上,最常见的是IE浏览器,这就是表示层的软件。表示层是直接与使用者交互的软件。
2.业务逻辑层
这一层一般在服务器端,顾名思义,所有业务逻辑处理都在这一层完成。最典型的是App Server,比如IBM的websphere,BEA的weblogic还有tomcat/jboss等。这一层也是三层中的重点,我们要说的大部分内容都是关于这一层的,这个等会再说,这一层就叫做中间层。
3.数据持久层
这一层典型的就是数据库,一般也在服务器端。但该服务器一般与装业务逻辑层软件的服务器分开,当然你也可以用IO输入输出流往硬盘上写东西,但没人会建议你这么做,因为这样做你的数据缺乏管理,不管怎样,这一层要做的就是保存数据,业务逻辑层软件一般不负责保留数据,或者说业务逻辑层只负责暂时储存数据,一关机,业务逻辑层数据全部over了,那么数据的持久化(也就是储存数据)就必须要在这一层完成。下面放着这些概念不谈,我们来说说将来的趋势。趋势一:
瘦客户端,很早很早以前,当时C/S模式也就是client/server。客户端软件大行其道的年代,一个pc用户,是采用一个傻终端连接到服务器上。然后进行相应的操作,最典型的就是我们上bbs经常用的c-term。这就是那个时代的产物,同样还有我国现行的机票定座用的e-term。后来呢,浏览器变得非常流行,人们发现,浏览器也能传递一些数据,虽然这些数据并不像那些终端那样准确,但应付大多数日常需求足够了。于是人们就提出一个瘦客户端概念,也就是说,将来表示层所有的其他软件疾挥?我们唯一需要的就是一个网页浏览器,然后通过浏览器输入ip地址连接到服务器,然后进行相关的操作。由于网页浏览器一般每个操作系统都有自带一个。这样做就达到了给我们客户端瘦身的目的(不需要安装额外软件)。这样模式被称作B/S模式,也就是browser/server模式。但需要指出的是,虽然瘦客户端是趋势,但并不代表胖客户端没有市场。尤其是一些复杂的业务操作,还是浏览器这种简单软件无法胜任的。趋势二:
傻数据库,ok,首先,我承认,这个名词是我发明的,但我实在无法找到一个更好的表达什么是傻数据库,如果谁对数据库有所了解的话,就知道,以前的数据库,有自己的一套管理体系,甚至有自己的客户端,比如oracle,mysql,Sqlserver都有。在某个管理工具上写什么sql语句查询数据库是我们以前常做的事。那么将来我们提倡的是:将所有的业务逻辑封装到业务逻辑层去,管理的事情由软件来做,由业务逻辑层的软件来做,所谓傻数据库就是说,将来的数据库什么事都不用做,只用把数据给我保存好就行了,那些复杂的业务逻辑什么外键什么关联,都没数据库什么事了,都交给业务逻辑层软件来做,这样做的好处就是:我们就不需要这些该死难懂又复杂的数据库系列管理工具了,而且这些工具每个数据库都有自己的工具,完全不一样,乱七八糟,没有人喜欢面对他们。除了数据库维护人员,也就是DBA,我们是软件工程师,维护的事让他们去做,而且严禁数据库维护人员改动数据库的数据,他们只做备份,必要时候恢复一下就是了。了解了这两个趋势之后,是不是有种砍头去尾保中间的感觉?没错,未来的趋势就是中间件时代,中间件工程师将是未来计算机应用的主流。那再次统一一下概念,什么是中间件?记得我上学的时候,看IBM的教材,看了半天中间件定义,就看懂记住一句话,中间件是做别人不愿意去做的事情,现在想想,狗屁定义,呵呵。什么是中间件,中间件是业务逻辑层的应用软件,是处理业务数据与客户端之间业务逻辑的一种应用软件,一种提供网络服务的服务器端应用软件。举个非常简单的例子,网上银行,某个人想用IE进入工行的账户,然后转帐。在这个例子中,客户端表示层显然是IE,数据持久层显然是银行的核心数据库。那么中间件是什么?中间件就是提供这种服务的系统。这三层的划分如下
------------------------------
|表示层 |业务逻辑层 | 数据持久层 |
------------------------------
| IE | 网上银行 | 数据库 |
------------------------------
给初学者之五:企业级应用之中间件
前面一篇简单介绍了一下应用软件的分层,下面重点介绍一下中间件,也就是业务逻辑层的软件结构 。从本系列第二篇我们知道,java程序是跑在虚拟机之上的,大致结构如下:
----------------------
| grogram |
-----------------------
| 虚拟机 |
----------------------
| 操作系统 |
-----------------------
也就是说操作系统先运行一个java虚拟机,然后再在虚拟机之上运行java程序,这样做的好处前面也说过了,就是安全,一旦出现病毒或是其他什么东西,挂掉的是虚拟机,操作系统并不会受多大影响 。这时候有人可能会问,为什么非要虚拟机?把操作系统当成虚拟机为什么不行?可以,当然可以,但是这样做某一个应用软件的bug就可能造成整个操作系统的死亡。比如说我们在某个服务器上安装了一个收发电子邮件的软件和java虚拟机,那么一旦黑客通过收发电子邮件的软件入侵系统,那么操作系统就整个玩完。那么如果黑客通过java程序进行攻击的话,那么死的将会是虚拟机而不是操作系统,大不了虚拟机崩溃,而操作系统正常运行不受任何影响。 举个简单例子,比如说最常见的是将数据库(DB)与中间件放在同一台服务器上
----------------------------------------------------------------------------------------------------
| program | |
----------------------------------------------------------| DB |
| 虚拟机 | |
------------------------------------------------------------------------------------------------------
| 操作系统 |
------------------------------------------------------------------------------------------------------
那么此时如果没有虚拟机,黑客病毒攻击中间件系统,就有可能造成操作系统的死亡,那此时数据库也有可能跟着一起玩完,那损失可就大咯 。那如果此时有虚拟机,那么一旦被攻击,死的是虚拟机,操作系统与数据库不受任何影响。嗯,回顾完虚拟机,再来介绍中间件 。在很早很早以前,任何一家企业,想要搭建一个局域网系统,他需要请许多个工程师。比如说我们想搭建一个网上银行,客户端用浏览器,后台数据库比如说用oracle。那么搭建这样一个网上银行,可能需要用到多少个工程师,我们来算一算。首先,由于客户端用的是浏览器,我们需要一些了解网络通讯协议以及一些浏览器标准的网络工程师。其次,由于后台数据库用的是oracle,那我们还需要请oracle的工程师,因为数据库这一层每个数据库公司的接口什么都不一样。然后,我们还需要一些操作系统的工程师,因为我们的系统需要跟操作系统直接交互。最后,我们需要一些设计网上银行系统及其相关业务的工程师 。太多了太多了,这样一个中间件队伍实在太庞大了,制作维护成本实在太高了。不仅如此,这样一个中间件就算做出来,他们所写的代码也只能满足这一家公司使用。其它公司统统不能再用,代码重用率极低,近乎不可能重用 。毕竟这个系统中改动任何一个部分都有可能涉及到整个系统的改动 。那么如何降低成本?
我举出了四组的工程师:
网络工程师,数据库工程师,操作系统工程师以及设计网上银行系统的业务工程师
除了最后一组设计网上银行的业务工程师之外,前面三组工程师是不是每一个项目都需要的?就算不是每一个项目都需要,至少也是绝大多数项目需要的吧? 哪个项目能够脱离网络,数据库和操作系统?不可能,在这个时代已经很少很少了。好,那既然每个项目都需要,我们是不是可以用一个产品来取代这三组的工程师呢?我们的业务工程师只需要遵循这个产品所提供的接口,进行相应的开发就行了。人们提出了一种叫做App Server也就是应用服务器的东西,应用服务器是干什么的?按官方的说法,应用服务器是包括有多个容器的软件服务器。那容器是什么?容器(Container)到底是个什么东西我想多数人还是不清楚。在说这个之前,先介绍一下组件 。什么是组件,组件是什么?组件其实就是一个应用程序块 ,但是它们不是完整的应用程序,不能单独运行。 就有如一辆汽车,车门是一个组件,车灯也是一个组件 。但是光有车灯,车门没有用,它们不能跑上公路 ,在java中这些组件就叫做javabean,有点像微软以前的com组件。要特别说明的是,由于任何一个java文件编译以后都是以类的形式存在
所以javabean肯定也是一个类,这是毫无疑问的。好,那么容器里装载的是什么呢?就是这些组件。而容器之外的程序需要和这些组件交互必须通过容器 。举个例子,IE发送了一个请求给容器,容器通过调用其中的一个组件进行相关处理之后。将结果反馈给IE,这种与客户端软件交互的组件就叫做Servlet。但是组件有很多种,那么如何区分这些组件呢? 有多种管理办法,比如同是同样是SERVLET,有些是通过JSP生成的,而有些是开发人员自己写的,那么通过JSP生成的SERVLET集中放在一个地方,而开发人员自己写的则需要在XML里面配置一些基本的参数。同时,不同组件有可能还需要继承一些特定的父类或者接口,这也是容器管理的需要.还有其他的一些组件,这里就不一一说明举例了 .那么容器有很多种,按照他们装载的组件类型划分 ,比如有装ejb的ejb容器,有装Servlet与jsp还有静态页面的web容器等.//这种只含有web容器的应用服务器也被叫做web服务器.当表示层的应用软件通过网络向App Server发送一个请求的时候,App Server自动找到相应容器中的组件,执行组件中的程序块,把得到结果返还给客户.而我们要做的事就是写组件也就是javabean,然后放到App Server里面去就可以了.至于怎样与IE通讯.怎样截获网络上的请求,怎样控制对象的数量等等.这些繁琐而无味的工作我们都不管,都由App Server去做吧,把注意力集中在业务逻辑上.App Server与其他相关软件的关系如下图:
-------------------------------------------------------
| 表示层 | 业务逻辑层 |数据持久层 |
-------------------------------------------------------
| | ----------------- | |
| IE | | javabean | | |
| -> ----------------- -> DB |
| client <- App Server <- |
| |-------------------------| |
| | 虚拟机 | |
|--------------|-------------------------|------------|
| Windows | Linux/Saloris |LinuxSaloris|
|--------------|-------------------------|------------|
图上可以看出:虚拟机负责处理中间件与操作系统之间的交互 ,App Server则负责组件的管理以及与其他两层的业务交互. 要说明的是上图中还包含有应用程序客户端容器(Application client container),管理应用程序客户端组件的运行,应用程序客户端和它的容器运行在客户机.这种情况比较复杂,一般说的是两个 server之间的通讯,比如jsp/Servlet容器在一个服务器上,而ejb容器在另外一个服务器上等等。这是分布式操作系统大面积应用的基础。嗯,那么话题再回到中间件上去,什么是中间件? App Server就是所谓的中间件,但是中间件不仅有App Server,还有其他的东西,换句话说,App Server只是中间件的一种。而关于中间件有诸多规范以及遵循这些规范的模型最流行的规范无非两种,一个是j2ee还有一个是.net。但是.net几乎只有微软在用,所以很多人把.net这个规范就当成是微软的中间件产品。也不为过,毕竟没几个公司喜欢跟着微软屁股后面跑的。
给初学者之六:java企业级应用之综合篇
我们知道中间件有很多种规范以及相关的模型,最流行的一个是j2ee还有一个是.net。那么各大公司关于这两套规范各有什么产品以及周边呢?
一。j2ee: 黄金组合
操作系统:Solaris 应用服务器:Weblogic 数据库:Oracle 开发工具:JBuilider/IntelliJ IDEA
优点:性能一级棒,大企业大公司做系统的首选,世界五百强几乎都是这套组合
缺点:极贵
超级组合,也是最安全最酷的黄金组合,硬件采用SUN公司的机器。但是SUN的服务器很贵,同等价格不如去买IBM的机器。SUN的服务器支持Solaris的效果自然不用说,Solaris号称是世界上最安全的操作系统。Oracle也是世界上最安全,性能最优的数据库,Weblogic是当今性能最优的App Server。JBuilder和IDEA各有所长,JBuilder是Borland公司的招牌之一,是当今世界上最流行的java IDE,用delphi写的,但网络上评价似乎不是很好。IDEA拥有插件功能,界面在所有java IDE中最为漂亮,东欧人开发的产品。东欧人严谨的作风在这个产品上体现得尤为突出,用java写的。IDEA甚至号称自己被业界公认为是最好的IDE//个人保留意见,没有最好只有更好。但我用JBuilder的时候发现了不少bug,而至今还没有在IDEA上发现什么bug
个人推荐IDEA
价格方面,Solaris开源,但是SUN的服务器比较贵,Weblogic最高是34万。oracle标准版要18.6万,企业版要49万,JBuilder要2.7万左右。IDEA零售价大概是500美金,也就是5000多元。另外,虽然理论上这些产品的综合性能要高于其他选择,但是必须看到 ,由于产商之间的利益冲突,比如oracle也有自己的App Server,但是性能不怎样,使得这几种产品之间协作的性能要比预想中的要差一点点 .
二。开源系列
操作系统:- 应用服务器:JBoss 数据库:MySql 开发工具:Netbeans
优点:便宜,性能未必最佳,但是对付中小企业足够了
缺点:出了问题自己抗吧
嗯,这是java阵营最大的特色,免费免费,还有在开发工具这一栏Eclipse也是免费的。但后面要说,算了,换个有代表性的开源产品来 。tomcat仅有web容器而没有ejb容器,而jboss已经集成了tomcat
也就是说下载了jboss之后,启动的同时也就启动了tomcat,jboss在tomcat基础之上多加了一个ejb容器,使得jboss+tomcat成为和weblogic,websphere之外又一个得到广泛应用的App Server 。现在大概是这样,中小型企业多用jboss,如果应用小一点就用tomcat,只有给那些大型企业做的项目,才会花钱去上一个weblogic或者websphere。mysql也是开源的数据库,做得非常不错,如果系统对数据库要求不高,或者安全要求不是非常严格,mysql是一个非常不错的选择。开发工具方面,netbeans是sun公司极力推广的一种IDE,听说在北美市场使用量已经超过eclipse了。操作系统,软件再不用钱,服务器也要钱,看这台机器上跑什么操作系统就用什么了。
三。IBM套餐
操作系统:Linux 应用服务器:Websphere 数据库:DB2 开发工具:Eclipse/WebSphere Studio
优点:服务好,IBM可以提供全套服务,也可以替客户承担风险
缺点:把机器数据全部交给IBM,安全什么的都由不得你了
呵呵,IBM全套产品,甚至包括硬件设备IBM的服务器,由于是一个公司的产品,各产品之间的协作自然不错 。价格方面,Linux,DB2,Eclipse都是开源产品,Websphere目前零售价是33.8万人民币,IBM服务器不错,可以考虑 。
四。微软阵营
操作系统:Windows 应用服务器:.net应用服务器(好像叫IIS) 数据库:SqlServer 开发工具:MS Visual Studio
优点:客户端的用户体验良好,和客户端诸多微软产品的兼容性强
缺点:离开了微软,寸步难行,和其他任何一家公司的产品都不兼容
微软的东西,怎么说呢,太专横了 。微软所有的东西都是围绕着windows来做的,.net其实已经可以实现跨平台了,但是微软出于自身商业考虑 ,在其应用服务器跨平台的实现上设置了种种障碍 ,而且针对windows,微软做了大量的优化,可以这么看,.net就是与windows捆绑的一套产品。所以有些人说,微软的产品离开了windows,就是渣。而且.net开源选择也少,安全性方面考虑,windows本身就有一堆补丁要打了。Sqlserver也不安全,至于.net到底安全不安全我不清楚,毕竟我没怎么用过.但整体考虑,感觉.net不是大企业的首选,鉴于其浓厚的商业背景,也不是中小企业的首选,但是必须看到 ,客户端也就是微机pc市场已经完全被windows所垄断,所以在一些快速开发,还有和微软产品兼容性要求较高的领域,.net还是比较有市场的.最后一个visual studio对它之前的版本兼容,且支持c,c++,c#,vb等语言
在其传统领域,比如写一些桌面软件等客户端应用上,.net还是第一选择.最后要说明的是 ,这些组合不是固定不变的 ,由于J2EE得到了绝大多数IT企业的支持以及JAVA跨平台的特性,我们可以自由地定制个性化的组合 .比如我可以选择windows+jboss+eclipse+oracle,也可以选择solaris+websphere+IDEA+mysql等等,这些自由组合都是可以的,但是有一点必须说明 ,微软的东西,一般来说离开了windows就不能用。比如你选择了.net应用服务器,那操作系统就必须是windows
你选择了Sqlserver,那就必须在windows上用。还有就是遵循j2ee规范的所有的组件都可以在不同的应用服务器上互相移植,比如你可以在测试的时候用jboss ,而在正式投产上线的时候使用websphere,只需要在配置文件中作相应改动即可。
给初学者之七:java企业级应用之术语篇
在了解完J2ee的相关周边产品之后需要深入J2ee规范内部去了解一下到底这些规范
这里介绍几个最常用的规范,再继续说下去之前有必要说几个常识。Java的诞生,Java之父James Gosling早年从cmu毕业之后,从事了一段时间的开发工作,后来意外碰到一个项目,这个项目要求他用C++开发,但可爱的JG是天才,凡是天才在某方面特别突出的同时,必然有一些天生的缺陷,恩,或说共性,比如说懒,急躁和傲慢。JG既然是天才,那就必然具备这些共性,JG懒,以至于他学不好C++。不仅他学不好,当年开发出Java的那个团队也都学不好C++。他们急噪,以至于他们中有人甚至威胁以辞职的方式离开这个需要使用CPP开发的项目。他们傲慢,所以他们决定开发出一种新的语言来取代那个该死的CPP。更可爱的是,他们一开始居然给这门语言起名C++++--//没错,我没敲错,叫什么C加加 加加减减,意思是加上一些好东西,减去一些坏东西,天才的设定,有时候你会发现天才和傻瓜真的只有一线之隔。还好这个可爱的名字没有被继承下来,这些天才们给他们的产物起名叫Oak//橡树。只是后来当他们去注册这个名字的时候,发现这个名字已经被注册了。于是在Sun公司的一个女职员//mm就是心细(这个说法也是我们公司mm告诉我的)的提议下,把这个可爱的语言起名为Java,就是他们当时喝的咖啡的名字。所以我们看到Java的标志就是一杯冒着热气的咖啡。JavaBean 了解完Java之后,再来说说什么是JavaBean//华为面试题JavaBean是什么? 咖啡豆
ja,更为科学点的解释是,用java语言编写的可重用的软件组件//组件的定义前面说过了,不再重复。很形象不是么? 将javabean放入杯子//容器,还记得容器的概念么?web容器,ejb容器。就可以冲泡//编译成咖啡,供客人们品尝//运行。完美的服务。下面进入正题,再谈容器。前面介绍过容器,我觉得有必要再补充一点,容器从某种意义上说其实就是一个可运行的java写的应用程序。犹如c++/c编译后生成的.exe文件,不同的是java编译后的文件需要用命令行或者脚本启动执行。由于容器是由java写的,所以容器都能够跨平台。虽说如此,似乎大部分容器都针对不同的操作系统提供了不同的版本。但可以肯定的一点是,相同容器间的移植组件不需要重新编译。。
Servlet web容器组件
Servlet确切地说,就是web容器运行的java组件,与普通javabean不同的是,Servlet定义了一系列方法//比如init()和destroy()供容器调用,调用的主要目的是为了管理。当一个request请求被web容器截获之后,容器分析该请求地址,然后通过一个配置文件中的映射表//web.xml。调用相应的Servlet组件处理后将结果返还给客户端。
JSP//Java Server Page,
web容器组件。Servlet出现了之后,人们发现几乎没有办法用一个非常直观的方式去编写页面,毕竟页面是html语言编写的,而让我们用一种流程式的处理方式去逐行教计算机如何写html代码太困难。在这种情况下JSP应运而生,JSP将java代码嵌入html代码内部,然后存成.jsp文件,再由计算机编译生成Servlet储存起来//注意这个过程,所以JSP和Servlet对于web容器来说其实是一种东西,虽然它们编写遵循的标准有所不同,极大地简化了代码同时增加了代码的可读性,生产维护成本下降。值得一提的是,在制定JSP规范的过程中,借鉴了ASP的很多规范。写过ASP并熟悉Java语言的人应该能很快掌握JSP。
EJB//Enterprise JavaBean
ejb容器组件,随着时间的推移,人们发现普通的JavaBean似乎并不能满足企业级应用的需要,最典型的就是虚拟机提供的垃圾回收收集机制也就是GC不够完善。可以优化的余地极大,在这种情况下,EJB应运而生。EJB和其它组件一样,不过遵循了某些规范而已,但是这些规范更多的是为充分利用机器并提高性能为主要目的的。举个简单例子,比如某个web服务器有100个用户同时连接上,由于网络连接是瞬时连接,所以很多时候并发数并没有100那么大,前一秒有可能有30个请求被发送过来并被处理,后一秒可以只有10个请求被发送过来并被处理 ,只有在非常非常极端的情况下才有可能发生100个请求同时被发送过来并被处理的情况 ,那么我们是否需要保留100个那么多个对象在服务器的内存里面去处理这些请求呢? 很显然,不需要,大多数时候//甚至可以说是所有时候,我不相信有那么极端的情况 ,我们只需要保存其中的10-30%就够了,那么什么时候需要20%,什么时候需要50% ,甚至100%,这个过程就交给容器去管理,这就是ejb容器每天在干的事 ,管理内存中活跃的对象。 恩,必须强调的一点是,由于使用的不成熟 ,我们经常把规范以及具体的应用两个名词混用 。举个简单例子,我们说Servlet,极有可能说的是Servlet规范 ,也有可能说的是一个具体的Servlet,这个就要看情况而定了 ,EJB,JSP也是如此。
JDBC
和数据库的连接,这个严格说来是数据库产商需要关心的事 ,关于AppServer如何与数据库的连接
但是也需要开发人员做一点事,因为AppServer不知道什么时候组件需要用到数据库 ,同时也需要开发人员告诉AppServer他们使用的是什么数据库,ip地址等等 。JDBC就是关于这一套东东的规范 ,包括数据库的产商应提供什么样的接口 ,AppServer应用服务器应该如何去连接 ,开发人员应该如何去配置这些连接等等 ,还有一些数据源,连接池等概念参考相关数据在此就不再赘述 。其它的规范比如JMX等确切地说与开发人员关联并不大了 。这类高级应用只对AppServer应用服务器产商重要 ,也不再罗嗦了 。记得听说过这样一种说法 ,大一时候不知道自己不知道 ,大二时候知道自己不知道 ,大三时候不知道自己知道 ,大四时候知道自己知道 。为什么呢,因为大一时候刚进大学,什么都不懂,很正常,大家都一样 ,大二或者大三时候开始接触知识,虽然还是不懂,但慢慢地开始学习,开始积累。过了一段时间,知道自己知道了//也就是前一种说法的大四,后一种说法的大三 。开始屁癫,开始拽得不得了,觉得自己怀才不遇,千里马难寻伯乐的那种感觉 。有些人是大四毕业了以后开始拽,悟性高一点的,大三就开始拽,因人而异 ,这几乎是每一个初学者经过一段时间学习后的必然阶段 。不管如何,总之开始入门了,这也不是坏事 ,但最后每个人都会知道自己不知道的,也就是后一种说法的大四阶段 。//前一种说法里面的那些家伙估计要到工作以后才能明白 ,因为任何一门学科都博大精深,要是能在两三年之内就统统搞懂 。那不是在吹牛就是坐井观天,java如此,c如此,c++也是如此。 那么到了本系列的第七集,可爱的读者应该处在什么阶段呢? 恭喜,在看完这篇文章之后,你就基本处于知道自己不知道的那种阶段 ,离拽起来还有那么一段距离,因为你们毕竟还没有学习和积累一定的基础知识 。但是骗骗外行,蒙蒙国企那些吃闲饭的管理人员问题不大。
给初学者之八:java高级应用之框架篇
没错,我没敲错,之所以不再声称是企业级应用而称之为高级应用是因为下面要讲的东西属于纯民间性质
是java具体应用的上层建筑,可用可不用,没有人强迫你用。首先给框架//framework 下一个定义,我想读者你可能听说过.net framework这个概念,没错,我们将要说的framework也和这个framework差不多,所不同的是.net framework的竞争对象是j2ee那一系列标准,而我们将要说到的几个框架则应用在j2ee的不同层面。单就单个框架而言,没有.net framework管得那么多,但是却要比它精专多了,而且总量加起来,也远比微软那一套框架要广泛得多。回到正题,框架是什么? 软件工程之所以被叫做软件工程就是因为有那么一批人觉得可以用工程学里面,那些管理Project的方法来管理软件从开发到维护这一系列流程。那么在建筑工程里面框架是什么? 现在建筑多采用钢筋混凝土结构,注意里面一个很重要的词汇:钢筋 。托福阅读中曾有一题听力就是关于钢筋结构的诞生,在美国 。恩,现代建筑中多在建筑起来之前,先用钢筋搭建出一个框架出来 ,然后往钢筋中间填入混凝土,从而形成一个完成的建筑。而今天要说到的框架就是这么一个东西在每一个软件中间的实现 。框架就是那么一个通过预先写好代码从而帮我们建立起一个软件结构的这么一个东西。这里提一下框架与规范//主要指J2ee规范也就是官方标准的区别
从某种意义上说,J2ee规范本身就是一个框架,无论是web容器也好,还是ejb容器也好,它们都开发了一部分通用的代码,并且帮助我们搭建起来了一个软件结构,我们要做的就是往里面填入组件。比如ejb/Servlet/jsp等等。没错,要这么理解也没错,但是为了避免混乱,我们还是严格区分开来 。本文中将要提到的框架如无特别说明,就是指的是非官方标准的框架 。规范是规范,而框架是建立在规范之上的一种东西 。可以说是标准的延续,或者说是民间的尝试,总之是这么一个非官方的东西。说到这里顺便提一下JCP组织也就是Java Community Process/Java社区,当初Sun公司在java发布之初,为了提倡开源和共项,同时也出于一个提出合理的标准的目的,而让广大的开发者参与标准的制定,而成立了这样一个社区,现在还健在,网址是jcp.org 。每一个新的规范发布之前都会在这个社区广泛讨论,最终对规范的制定产生巨大的影响,其中就包括企业级的参与者,相当有名的JBoss以及我国的金碟公司都是其中的成员。下面介绍一下几个相当著名的框架,必须要指出的是,虽然框架大多开源但并不代表所有的框架都开源,比如.net framework,但是java框架大多数开源。言归正传
Struts
表示层框架,名字来源于飞机的金属框架 。可能有读者会提问了 ,表示层不是客户端么? 没错,但是语言这东西,众口烁金,别人都这么说你就不好不这么说了 。最早表示层说的是客户端,后来随着时间的发展 ,人们也把服务器端直接与客户端//比如IE,打交道的那部分也称为表示层//JSP+Servlet 。那么表示层框架是干什么的呢? 早先大规模应用JSP的时候,人们发现,JSP里面充斥着逻辑代码与数据,可读性极差,于是人们借用很早很早以前的MVC模式的思想,把表示层组件分为V-Viewer,也就是JSP M-Model模型,一般来说是一个JavaBean ,C-Controller控制器,一般来说是一个Servlet 。所有人通过JSP和服务器打交道,发送请求,Viewer把这个请求转发给Controller。Controller通过调用一个Model来处理该请求,然后返回数据到Viewer,这么一个过程,从而达到数据与逻辑的剥离,增强代码可读性,降低维护成本。而帮助人们实现这一系列东西的就是Struts框架,就是这么一个东西,Struts的竞争对手主要是产商们极力倡导的JSF也就是Java Server Faces。但是由于Struts出道时间早,所以应用比较多。JSF则是产商们大力支持,前景看好 ,对于这一层来说,在JSP的html代码中出现的java语句越少越好,因为java代码越少说明页面处理的业务逻辑越少,也越合理。这也是Struts最初的目的,记住这话。
Spring
大名鼎鼎的Spring框架,有人曾说2005年一片叫春之声,指的就是该框架。Spring起源于Rod Johnson的《Expert One-on-One J2EE Design and Development》一书。Rod Johnson认为,J2ee里面的那一套//尤其是ejb,太重了,对于单机的系统来说,没有必要使用那么复杂的东西 。于是就开始设计并引导Spring小组开发出这样一个构架,不能不说他是个天才,因为的的确确不是所有的系统都是跨多服务器的 。没有必要把一个简单的系统设计得那么复杂//天才的那几个共性又体现出来了,Spring从诞生之日起就是针对EJB的,力争在不少应用上取代EJB,而它也确实达到了这个目的 ,现在包括WebLogic等主流应用服务器还有主流IDE都开始逐渐接受该框架,并提供相应支持 ,提到Spring就不能不说控制反转Ioc//Inversion of Control和依赖注射DI//Dependency Injection 。什么叫控制反转呢?套用好莱坞的一句名言就是:你呆着别动,到时我会找你。什么意思呢?就好比一个皇帝和太监 ,有一天皇帝想幸某个美女,于是跟太监说,今夜我要宠幸美女 ,皇帝往往不会告诉太监,今晚几点会回宫,会回哪张龙床,他只会告诉太监他要哪位美女,其它一切都交由太监去安排,到了晚上皇帝回宫时,自然会有美女出现在皇帝的龙床上,这就是控制反转。而把美女送到皇帝的寝宫里面去就是注射 ,太监就是是框架里面的注射控制器类BeanFactory,负责找到美女并送到龙床上去。整个后宫可以看成是Spring框架,美女就是Spring控制下的JavaBean。而传统的模式就是一个饥渴男去找小姐出台 ,找领班,帮助给介绍一个云云,于是领班就开始给他张罗 ,介绍一个合适的给他,完事后,再把小姐还给领班,下次再来 。这个过程中,领班就是查询上下文Context,领班的一个职能就是给客户找到他们所要的小姐,这就是lookup()方法,领班手中的小姐名录就是JNDI//Java Naming and Directory Interface。小姐就是EJB,饥渴男是客户端,青楼是EJB容器,看到区别了么?饥渴男去找小姐出台很麻烦,不仅得找,用完后还得把小姐给还回去,而皇帝爽翻了,什么都不用管,交给太监去处理,控制权转移到太监手中去了,而不是皇帝,必要时候由太监给注射进去就可以了 。看到Spring的美妙了吧,Spring还提供了与多个主流框架的支持
可以和其它开源框架集成 。
Hibernate
名字取材自ORM最早的一句玩笑话//ORM就是OR-Mapping,说用了ORM之后,程序员就可以去冬眠了,而不需要操心那么多事。这里不得不说的是,该框架由于做得太好,以至于被J2ee招安,成为EJB3.0的一部分,替代原有EJB2.X里面关于Entity Bean而成为EJB ORM的工具。这里解释一下,ORM//OR-Mapping 中文名对象关系映射 ,什么意思呢?我们知道传统的数据库都是关系型的 ,一条条记录以表格的形式储存,而表与表之间充斥着是关系/关联。比如说一个人,名字zhaoce,性别男,年龄23,那么数据库中是这么储存的。姓名性别年龄 zhaoce m 23 某女 f 22,而实际应用服务器中的实体都是以对象的形式存在,一个个对象 ,zhaoce是以这种形式存在的
Human human=new Human();
human.setName("zhaoce")
human.setSex("m");
human.setAge(23);
这样的,那么我们知道,传统的JDBC是通过一个二维字符串将数据取出,需要我们自己将其包装成对象,在存入的时候,我们还需要将对象拆开 ,放入sql语句中
//Insert into Huamn values('zhaoce','m',23)
然后执行该sql语句,太麻烦太麻烦,ORM理念的提出改变了这一切,ORM认为,这些东西应该由框架来做,而不是程序员,程序员做他该做的,不要为这种破事分心,还测试半天 ,于是就出现了Hibernate,JDO,TopLink等等,甚至.net里面也有ADO.net。过去一段时间是Hibernate和JDO争风,现在看来Hibernate逐渐成为主流并被官方接纳,成为规范标准之一,替代掉原来EJB2.X的ORM EntityBean,TopLink则是Oracle公司推出和Oracle数据库结合的一种ORM,商业用软件,贵且复杂,不过正在逐渐开放 ,而像表示层一样,这一种专门面对数据层的代码也被称为数据持久层 ,所以数据持久层这一概念有时不仅仅指代数据库 。关于ORM,最高的境界应该是在java代码中不出现任何一句的sql语句,注意,是不包括sql语句,Hibernate的hql以及ejb的ejb-ql不算在内。至于出现不出现hql/ejb-ql等替代ql,这要视具体情况而定,不过最好也是不出现,当然最后所说的过分理想的情况往往不现实,总之一句话 ,以sql为代表的ql/*还有hql,ejbql等*/语句在代码中出现得越少越好。记住这话,现在未必能够理解,学了以后就懂了。这三个是目前最为常用的框架而目前光已公布的框架就>500 ,还在不停增加中,不可能一一列举,有兴趣的可以去看相应文档要指出的是框架不是应用程序,只是一堆组件的有序复合,应用时不能脱离于应用服务器单独存在。
给初学者之九:收尾
最后一篇介绍几个常见的概念,
设计模式
这可不仅是java独有,我看的书就是c++和smalltalk例子的。先说说什么是设计模式。模式是什么?模式是经验的总结,潜规则的抽象 。什么意思呢?比如说我们坐飞机,上飞机前需要经过几个步骤 ,什么安检领取登机牌之类的,这一套流程能不能改呢? 可以,但为什么几乎全世界的航空公司登机前都是这一套流程呢? 因为航空公司经过长期实践之后得出了一堆结论和经验 ,并认为这样做才是最安全,或说是最有效率的 ,这就是模式。模式是编程高手之间交流的桥梁 ,两个编程高手通过统一命名的模式了解对方的思想 。当然不借助模式可不可以?当然可以,只是模式无处不在,你不知道而已。又比如吃饭,每吃一口饭,我们要先端碗,拿筷子,张嘴,塞饭入口,咀嚼最后吞咽,这就是一套模式,我们给这套模式命名为吃饭。
那么当老爸叫吃饭的时候,我们就能明白什么意思 。而不用老爸进来呓呓啊啊并比画上半天,哑语也不是这么用的 ,这就是模式,已知的模式有400多种。//好象更多,不记得了。比如数据库有数据库的设计模式,编程有编程的模式等等。 面向对象有常用的21种模式,需要掌握,主要分为创建,行为,结构三类。
J2ee有J2ee的模式,Sun公司出了一本书叫《J2EE核心模式》可以拿来看看。必需要指明的是,模式不是规范,比如吃饭模式 ,没有人规定你吃饭非得要那么吃,你可以端碗,上抛,张嘴在下落后连碗一起吞咽,这也可以,只要你愿意,同样,只要你愿意,你就可以不遵循模式 。模式之外还有反模式,学模式不可定势,不要学死,活学活用,无招胜有招才是最高境界。
JavaDoc 文档工具,极其好用 ,可以根据注释自动生成HTML文档。
Ant 98年,有一位程序员在从欧洲飞回美国的飞机上想到了这么一个东西 ,从而改变了整个世界,他的名字叫James Duncan Davidson组织管理工具,可以这么描述它 。比如你想在编译之后自动再次生成JavaDoc ,那么你只需要编辑Ant脚本//对,就像Windows脚本那样,然后批处理就可以了,不过现在Ant已经广泛集成到IDE中去,不需要自己手动编写,不过如果想要炫炫,据说此招百试不爽 。
JUnit 测试工具,Unit家族可不只有JUnit,还有其它版本的,这个不细说,具体实践一下就明白了。
POJO //Plain Old Java Object 就是传统的Java对象,也就是一个JavaBean,由虚拟机来掌握其生死 。常用的两个管理构架/规范是Spring和EJB容器,命名由来是某人//名字我忘了,觉得我们使用了太多的规范,以至于我们都忘记了纯粹的java对象,以至于我们都忽略了它的存在,所以叫了这么一个名字 ,以唤醒人们的记忆,这个意义上来说EJB其实不能算是POJO,毕竟遵循了一堆的接口,但是不管怎样,接口归接口,还是没有继承类 ,没有被强加什么。//遵循可以写空方法假遵循,所以说还是POJO也对。但是由于这种东西缺乏管理,不象Servlet有专门的容器管理并继承了一定的类。而没有管理的对象在虚拟机中是很危险的,因为垃圾回收机制各个虚拟机不同。而且也不怎样,极有可能长时间不回收,这样在企业级的应用中呢 ,就有可能造成内存大量被占用从而死机,毫无疑问,这种机制需要优化 。这种优化就是通过EJB容器或者Spring构架来实现。这么做还有一个好处就是迫使程序员对每一个类做封装
强迫他做管理,以达到防止内存泄露的目的,内存泄露最经常出现的错误就是引用未释放,引用最典型体现在new这个关键字上,new得越多引用得越多,随着时间地增长,有可能导致循环,不停new new new new new.....其中哪怕只要有一个new处理不当,虚拟机无法回收内存,那就极有可能完蛋,而且这种小bug越是在大的项目越是难以找到,有可能因为一个人而影响整个项目组,所以不妨记住我的一条经验,
好的系统框架不应该在业务逻辑流程中出现new关键字。现在不理解也无所谓,将来有一天会明白的 。
SOA 面向服务的构架 ,不说太多,这个属于上上层建筑 。不过不妨记住我的一句话,可以帮助理解这个概念 ,面向什么就是对什么做封装 ,面向对象就是对对象做封装 ,面向服务类似,剩下的靠悟性 。
反射 1.4新增功能,非常强大 通过反射,程序可以解析出类本身的属性也就是变量//注意这里说的属性不是.net里面的属性,我不喜欢微软造的新名词,乱。还有行为也就是方法,然后通过invoke()方法调用该方法,甚至可以新增对象等,java首创,本是其它语言所没有的。后来被微软抄了去,利用该功能,开源框架广泛受益并大量采用,近乎疯狂地使用,具体就不说了,最后要指出的是,有一种说法是利用反射会降低效率 。在早期的时候的确是,现在不会了,放心使用 。
容器 5.0以后的版本在J2SE中都出现了容器,各位甚至可以自己尝试用标准库去使用容器 。