Java的套用可以说是无处不在,从桌面办公套用到网路资料库等套用,从PC到嵌入式移动平台,从Java小应用程式(Applet)到架构庞大的J2EE企业级解决方案,处处都有Java的身影,就连美国大型太空项目当中,也使用了Java来开发控制系统和相关软体。用途如此之广的Java造就了Java工程师的辉煌,使其在软体工程师的领域里独占鳌头!Java软体工程师运用Java这种程式语言去完成软体产品的软体程式设计、开发、测试、维护升级等工作。
基本介绍
- 中文名Java
- 外文名Java
- 工作内容完成软体的设计、开发、测试等
- 套用範围无处不在
- 所属类型软体工程师
基本简介
工作内容
完成软体的设计、开发、测试、修改bug等工作,包括业务需求的沟通,功能模组详细设计,业务功能实现与单元测试,系统维护;
参与产品构思和架构设计;
撰写相关的技术文档;
支持售前技术服务;
支持项目对产品的套用服务。
薪资行情
根据IDC的统计数字,在所有软体开发类人才的需求中,对Java工程师的需求达到全部需求量的60%~70%。,Java工程师的薪水相对较高。Java软体工程师一般月薪範围在6000-10000元,远远超过了应届毕业生月薪3000元的平均水平。通常来说,有2年工作经验的Java高级软体工程师的薪酬大致在年薪10—15万左右。
职业要求
教育培训
计算机相关专业,大专及以上学历。相关专业证书有Sun Certified Java Programmer(SCJP)和Sun Certified Java Developer(SCJD) 认证。目前国内在java软体工程师培训中有名的是软帝科技,NIIT,达内科技等,这些都是拥有很多年的办学经验,在java软体培训上拥有其独特的优势。
工作经验
有一定的软体分析设计能力;熟悉Java、Servlet、JSP、EJB等开发技术;熟练使用Eclipse、MyEclipse、NetBeans、jbuilder等java开发工具;熟悉三大框架体系结构和开发工具;熟悉至少一种资料库的开发和设计;具有良好的学习能力,具有强烈的工作责任心、有良好的沟通能力和团队合作精神。
发展路径
概述
虽然Java人才的薪水很高,对该类人才需求旺盛的IT企业却很难招聘到合格的Java软体工程师。其中,最根本的原因就是许多计算机专业的毕业生在读期间没有掌握实用的技能与经验,距离企业的实际用人要求有较大的差距。,计算机专业的大学生欲成为Java软体工程师,最便捷的一条路就是参加以实战项目为主要教学方法的Java职业技能培训,从而有效地缩短同企业具体用人要求之间的差距。
分类
Java软体工程师的未来发展方向大致分为两类
一是成为管理人员,例如产品研发经理,技术经理,项目经理等;
二是继续他的技术工作之路,成为高级软体工程师、需求工程师等。
Java简介
Java语言是一个面向对象的。Java语言提供类、接口和继承等原语,为了简单起见,只支持类之间的单继承,但支持接口之间的多继承,并支持类与接口之间的实现机制(关键字为implements)。Java语言全面支持动态绑定,而C++ 语言只对虚函式使用动态绑定。,Java语言是一个纯的面向对象程式设计语言。
Java语言是分散式的。Java语言支持Internet套用的开发,在基本的Java套用编程接口中有一个网路套用编程接口(java net),它提供了用于网路套用编程的类库,包括URL、URLConnection、Socket、ServerSocket等。Java的RMI(远程方法激活)机制也是开发分散式套用的重要手段。
Java语言是健壮的。Java的强类型机制、异常处理、废料的自动收集等是Java程式健壮性的重要保证。对指针的丢弃是Java的明智选择。Java的安全检查机制使得Java更具健壮性。
Java语言是安全的。Java通常被用在网路环境中,为此,Java提供了一个安全机制以防恶意代码的攻击。除了Java语言具有的许多安全特性以外,Java对通过网路下载的类具有一个安全防範机制(类ClassLoader),如分配不同的名字空间以防替代本地的同名类、位元组代码检查,并提供安全管理机制(类SecurityManager)让Java套用设定安全哨兵。
Java语言是体系结构中立的。Java程式(后缀为java的档案)在Java平台上被编译为体系结构中立的位元组码格式(后缀为class的档案),然后可以在实现这个Java平台的任何系统中运行。这种途径适合于异构的网路环境和软体的分发。
Java语言是可移植的。这种可移植性来源于体系结构中立性,,Java还严格规定了各个基本数据类型的长度。Java系统本身也具有很强的可移植性,Java编译器是用Java实现的,Java的运行环境是用ANSI C实现的。
Java语言是编译解释型的。如前所述,Java程式在Java平台上被编译为位元组码格式,然后可以在实现这个Java平台的任何系统中运行。在运行时,Java平台中的Java解释器对这些位元组码进行解释执行,执行过程中需要的类在联接阶段被载入到运行环境中。
Java是高性能的。与那些解释型的高级脚本语言相比,Java的确是高性能的。事实上,随着JIT(Just-In-Time)编译器技术的发展,Java的运行速度可以和最佳化过的本地代码相媲美。
Java语言是多执行绪的。在Java语言中,执行绪是一种特殊的对象,它必须由Thread类或其子(孙)类来创建。通常有两种方法来创建执行绪其一,使用型构为Thread(Runnable) 的构造子将一个实现了Runnable接口的对象包装成一个执行绪,其二,从Thread类派生出子类并重写run方法,使用该子类创建的对象即为执行绪。值得注意的是Thread类已经实现了Runnable接口,,任何一个执行绪均有它的run方法,而run方法中包含了执行绪所要运行的代码。执行绪的活动由一组方法来控制。Java语言支持多个执行绪的执行,并提供多执行绪之间的同步机制(关键字为synchronized)。
Java语言是动态的。Java语言的设计目标之一是适应于动态变化的环境。Java程式需要的类能够动态地被载入到运行环境,也可以通过网路来载入所需要的类。这也有利于软体的升级。,Java中的类有一个运行时刻的表示,能进行运行时刻的类型检查。 Java语言的优良特性使得Java套用具有无比的健壮性和可靠性,这也减少了套用系统的维护费用。Java对对象技术的全面支持和Java平台内嵌的API能缩短套用系统的开发时间并降低成本。Java的编译一次,到处可运行的特性使得它能够提供一个随处可用的开放结构和在多平台之间传递信息的低成本方式。特别是Java企业套用编程接口(Java Enterprise APIs)为企业计算及电子商务套用系统提供了有关技术和丰富的类库。
和C/C++的差异 熟悉C语言和C++语言的读者一定想搞清楚这个问题,实际上,Java确实是从C语言和C++语言继承了许多成份,甚至可以将Java看成是类C语言发展和衍生的产物。比如Java语言的变数声明,操作符形式,参数传递,流程控制等方面和C语言,C++语言完全相同.儘管如此,Java和C语言,C++语言又有许多差别,主要表现在如下几个方面
(1) Java中对记忆体的分配是动态的,它採用面向对象的机制,採用运算符new为每个对象分配记忆体空间,而且,实际记忆体还会随程式运行情况而改变。程式运行中 Java系统自动对记忆体进行扫描,对长期不用的空间作为”垃圾”进行收集,使得系统资源得到更充分地利用.按照这种机制,程式设计师不必关注记忆体管理问题,这使Java程式的编写变得简单明了,并且避免了由于记忆体管理方面的差错而导致系统出问题。而C语言通过malloc()和free()这两个库函式来分别实现分配记忆体和释放记忆体空间的,C++语言中则通过运算符new和delete来分配和释放记忆体。在C和C++这种机制中,程式设计师必须非常仔细地处理记忆体的使用问题。一方面,如果对己释放的记忆体再作释放或者对未曾分配的记忆体作释放,都会造成当机;而另一方面,如果对长期不用的或不再使用的记忆体不释放,则会浪费系统资源,甚至造成资源枯竭。
(2) Java不在所有类之外定义全局变数,而是在某个类中定义一种公用静态的变数来完成全局变数的功能。 (3) Java不用goto语句,而是用try-catch-finally异常处理语句来代替goto语句处理出错的功能。 (4) Java不支持头档案,而C和C++语言中都用头档案来定义类的原型,全局变数,库函式等,这种採用头档案的结构使得系统的运行维护相当繁杂。
(5) Java不支持宏定义,而是使用关键字final来定义常量,在C++中则採用宏定义来实现常量定义,这不利于程式的可读性。
(6) Java对每种数据类型都分配固定长度。比如,在Java中,int类型总是32位的,而在C和C++中,对于不同的平台,同一个数据类型分配不同的位元组数,同样是int类型,在PC机中为二位元组即16位,而在VAX-11中,则为32位.这使得C语言造成不可移植性,而Java则具有跨平台性(平台无关性)。
(7) 类型转换不同。在C和C++中,可通过指针进行任意的类型转换,常常带来不安全性,而在Java中,运行时系统对对象的处理要进行类型相容性检查,以防止不安全的转换。
(8) 结构和联合的处理。在C和C++中,结构和联合的所有成员均为公有,这就带来了安全性问题,而在Java中根本就不包含结构和联合,所有的内容都封装在类里面。
(9) Java不再使用指针。指针是C和C++中最灵活,也最容易产生错误的数据类型.由指针所进行的记忆体地址操作常会造成不可预知的错误,通过指针对某个记忆体地址进行显式类型转换后,可以访问一个C++中的私有成员,从而破坏安全性。而Java对指针进行完全地控制,程式设计师不能直接进行任何指针操作。
(10)避免平台依赖。Java语言编写的类库可以在其它平台的Java应用程式中使用,而不像C++语言必须依赖于Windows平台。
(11)在B/S开发方面,Java要远远优于C++。
Java前景
自从sun被甲骨文收购以后,Java的发展前景就变得扑朔迷离起来,很多程式开发者都感到很迷惑。2010年4月9日,被称为Java之父的JamesGosling又在个人部落格上宣布离开Oracle,这一事件更为Java的前景增加了一层迷雾。在进入5月份之后,一切开始变得明朗起来。 是Oracle在Java的后续支持方面,宣布了一系列关于Java的相关计画。然后是Java之父JamesGosling继声明Java不会死去之后又盛讚Oracle对Java所做的贡献。在Oracle的活动发布网站上,连续发布了多个关于Java的推广活动。
版本简介
2010年5月12日,Oracle主要产品负责人DaveHofert将大谈对JavaSE商业套用的改进和革新。根据宣传资料,在这次演讲中,DaveHofert将提到以下问题
商业版与社区版本之间平台支持的差异。
如何获得专家帮助,以帮助企业增强其Java套用。
对于旧版本的安全修补问题。
可使用的发布工具和更新。
2010年6月18、19、20、27日,将分别在赫尔辛基、斯图加特、布达佩斯、伦敦举行Oracle、Sun专家与用户见面会,在见面会上与用户一起探讨Java的发展路线。主要讨论的问题包括Oracle将如何继续投资和改进Java技术,并且还会向用户通报JavaSE、JavaME专家团队的最新讯息、JavaFX和JDK7最新的讯息,以及OracleBerkeley DB的相关信息。
2010年5月3日,已经离开Oracle近一个月的Java之父JamesGosling在他的部落格上表达了对NetBeans 6.9 和 FX1.3发布的关心。这两个项目最新版本的发布,可以证明Oracle已经开始兑现当初的承诺。JamesGosling在其早期的部落格中,也透露了不会放弃Java事业,只是需要解决一些与Oracle之间的法律问题。
这一切迹象表明,Oracle绝对不会轻易放弃Java这块巨大的蛋糕,并且Oracle也开始逐渐学会了对开源社区的尊重。在JDK的商业版本方面,Oracle将会继续深入挖掘Java的商业利益,与其固有产品进行更深入的整合。在社区版本方面,Oracle将与Java开发者一起探讨和研发Java的技术。这里需要特别提到的一个产品是OracleBerkeleyDB,该产品是Oracle一直支持的一个开源非关係资料库产品,在NOSQL大行其道的今天,如果Oracle能够将BerkeleyDB与Java进行深入整合,将会为Java带来更多的活力和生命。从JamesGosling的表现来看,他似乎与Oracle之间已经达成某种谅解,并且有进一步合作的可能性。
java发展
Java在日新月异的IT技术领域内不算年轻,在过去的十几年中,Java曾凭藉开放和跨平台等特性、藉助网际网路蓬勃发展的东风,改变了C/C++称霸天下的局面,形成Java、C、C++三足鼎立的格局。特别是Java在程式语言排名榜上独占鳌头长达10年之久,并帮助Sun奠定了其在IT技术和开源领域的地位,都说明Java在开发领域中的重要性。
在未来发展方向上,Java在Web、移动设备以及云计算方面前景非常广阔。虽然面对来自网路的类似于Ruby on Rails这样编程平台的挑战,Java依然还是事实上的企业Web开发标準。在Java对新开发者吸引力方面,这幺多年以来,Java一直都在面对那些不成熟的,基于脚本的程式语言的挑战。比如PHP和Ruby,虽然经过多年努力,并没有看到他们相具有比Java更强的竞争力。另一方面,随着云计算以及移动领域的扩张,更多的企业在考虑将其套用部署在Java平台上,无论是本地主机,公共云,Java都是目前最合适的选择。
事实上Java技术的开放性、安全性和庞大的社会已有资源,以及其跨平台性,即“编写一次,到处运行”的特点,也使Java技术成为智慧型手机软体平台的事实标準。採用Java技术后,编写应用程式和提供服务的人就不必关心接受其服务的手机採用的是什幺作业系统和晶片,只要按照Java的要求去写程式就好了;同样,生产手机的厂商也不必顾虑将来谁来提供增值服务。在Oracle的技术投资担保下,Java也将是企业在云套用方面迴避微软平台、在移动套用方面迴避苹果公司的一个最佳选择。比如VMware就宣布了一个称为VMforce的服务,该服务将在云计算机中布置Java套用,Google套用引擎也将一如既往的支持Java。他们都是微软提供的,基于.Net和开源PHP语言基础上的Azure云平台的竞争对手。,进军传统的桌面套用仍是Java未来一个努力的方向之一。
JAVA作为主流的商业套用的语言在3G、物联网时代下焕发出新的生机!
在网际网路时代,JAVA语言已经是使用最广泛的伺服器端语言。随着3G、网际网路时代的到来,JAVA语言并不会“过时”,相反,JAVA语言会在新的业务领域有着更辉煌的发展前景。
3G、网际网路的发展不仅仅带动了“智慧型手机製造业”、“电信运营业”、“RFID产业”、“嵌入式设备”等硬体或系统软体行业的发展;更重要的是3G、网际网路开创了更多、更新的商业领域套用,而这些领域的核心程式语言仍然是JAVA!
在TTS4.0 课程体系中的基于智慧型手机平台的“航空公司移动服务门户”项目和基于全球定位、实时订单跟蹤、RFID仓储管理等诸多网际网路新技术的“新一代物流管理系统”都是这些新商业套用领域的典型代表。
未来趋势
对Java来说,2010年是不平凡的一年,从Oracle在年初完成对Sun的收购,使大家对Java的未来充满了关注,而12月份在北京进行的JavaOne大会,可以说是Oracle在收购Sun之后的第一次正式大会,大家可以从 JavaOne上更多了解了Java未来的发展。而2011年,将成为Java新的开始。
Java走过了它15年的历程,在日新月异的IT技术领域不算年轻,但它一直没有停下变革、创新的脚步。Java已经不单单是一种计算机语言,很多情况下,我们称它是一个平台,一个社区。下面从Java SE、Java EE、Java ME、JavaFX几个方面,展望Java技术在2011年的发展。
Java SE
从Oracle公布的Java未来战略我们可以看到,Oracle目标是加强和继续扩大Java在新领域的套用,并将Java平台纳入新的部署架构,加大对 Java社区的投资,允许社区更多地参与。开发人员比较关注的Java SE 7将会在2011年夏天就绪,其中JCP已经批准了JSR 334、JSR 335、JSR 336和JSR 337等,支持改进Java语言和API规范,比如switch in string、multi-catch、泛型实例创建中的precise rethrow、Lambda表达式(闭包)等。而Java SE 8也将在SE 7发布之后的一年到一年半的时间就绪。
模组化的VM可以将VM拆分成小块由应用程式使用,并按需推向Internet,这样的结果是Java应用程式的启动时间更短了,当VM不在目标机器上时,下载的时间也更短了。
额外的语言支持Java平台支持用不同语言编写的应用程式,未来将会添加更多的语言支持,也包括对动态语言的支持,这就是所谓的达文西机或多语言虚拟机,请参考JSR-292。
增强的多核支持需要藉助工具、库和内置设施帮助新的和现有的Java应用程式更有效地利用多核硬体的优势,Java的执行绪模型可以轻鬆地创建并行执行任务的执行绪,但你如何将一个单一的任务拆分成多片进行并行执行呢?
其它改进包括持续的性能改进,以及许多语言方面的增强,包括增加的闭包,在switch语句中对Strings的支持,以及多块异常捕获,闭包是一个有争议的功能,它是通过使用匿名的Java内部类实现的。
Java EE
Oracle长期以来一直都是Java的支持者,也是最大的JCP成员之一,10多年前就开始参与Java EE规范的编制,对Oracle成为Java中间件市场的大鳄不应该感到意外。
Java EE展望
模组化,开发标準Java EE 6通过配置档案(Profile)定义实现了模组化Java EE,允许厂商根据特定需求创建更小的Java EE堆叠子集,解决成本和Java EE使用複杂问题。通过模组化设计和定义标準,有助于简化Java EE,让它的套用领域更广泛。
Java EE 6规定了两种配置档案Web配置档案(Servlet,JSP和JSF)和Java EE企业配置档案。显然还可以定义更多的配置档案种类,例如,为支持会话初始化协定(SIP)定义电信伺服器配置档案。
UI和RIAHTML仍然是Java EE应用程式隐含的UI协定,通常有Java Servlet,JSP和JSF生成,考虑到生产的Web页面是静态的,可以使用Ajax技术,不过它已经超出了Java EE的範畴。
虽然Oracle没有明确这方面的具体计画,但未来Java EE和JavaFX集成时将会解决Ajax问题。
Java ME
作为 Oracle 首选的移动环境的 Java,这个堆叠未来默认的呈现方式将会是 HTML, CSS 和 Javascript。Java ME 将包含 WebKit 引擎,JavaScript. 引擎,和 Java/JavaScript. 桥,换言之,未来运行新版 Java ME 的手机,将能够访问浏览器以外的 Web 服务,而不会有任何性能问题。这些引擎将直接插入 Java ME虚拟机和插入 Java FX。
Oracle 的 Java ME 引擎,将利用当代图形硬体加速器所擅长的(60 frames/秒)二维和三维渲染(在 Windows 环境下,微软的 Direct X,还有 OpenGL 或未来“更好”的技术)。 Java ME 将会针对 ARM7 和 ARM9晶片组进行最佳化,包括 Broadcom,三星,NEC,德州仪器,以及其他取得授权的手机部件製造商,还将内置充分利用手机装置的支付,通话,和定位等功能的 API。
JavaFX
随着 JavaFX 和 Java 的整合,并运行于 JVM 之上,它的富媒体处理及二维和三维渲染功能,也将能提供给任何在 JVM 上运行的其他程式语言,这意味着,例如 Groovy, Scala 和 JRuby 等也都能用来整合 JavaFX 的能力。
JavaFX展望
基于可视化组件创建一个设计範式
为JavaFX应用程式创建一个丰富的UI扩展库
提升所有平台的JavaFX性能
增强跨设备移植JavaFX应用程式的能力
与Java,JavaScript和HTML 5无缝集成
支持新兴设备和UI範式(如多点触摸)
基础技能
初级部分
Java OO程式设计基础,包括 J2sdk基础、Java面向对象基础、Java API使用、数据结构及算法基础、Java AWT图形界面程式开发;
J2SE平台Java程式设计,包括Swing图形程式设计, Socket网路应用程式设计,对象序列化,Java 常用数据结构,Applet,流和档案,多执行绪程式设计;
Java桌面系统项目开发,4~5人组成一个项目组,项目大小为(15人工作日);
Linux的基本操作,Linux下的Java程式开发,Linux系统的简单管理;
Oracle资料库,包括SQL/PLSQL;资料库和资料库设计;简单掌握ORACLE9i 资料库的管理;
中级部分
Java Web套用编程,包括 Java Oracle 编程,即JDBC;Java Web编程,包括JSP、Servlet,JavaBean;Java套用编程,包括Weblogic、Websphere、Tomcat;以及利用Jbuilder开发Java程式;
MVC与Struts,学习业界通用的MVC设计模式和Struts架构;
Java B/S商务项目开发,4~5人一个项目组,项目大小为(25人工作日左右)
高级部分
J2ME程式设计,包括J2EE程式、J2ME;Java高级程式设计(J2EE),包括J2EE体系结构和J2EE技术、EJB;Weblogic使用、 JBuilder开发;
Java和XML,包括Java Web Service,Java XML, 业界主流XML解析器程式设计;
软体企业规范和软体工程,包括UML系统建模型和设计(Rational Rose 200x)软体工程和业界开发规范;CVS版本控制、Java Code书写规范;
J2EE商务套用系统项目开发,4~5人一个项目组,项目大小为(25人工作日左右)
架构设计
体现
软体架构作为一个概念,体现在技术和业务两个方面。
从技术角度来说软体架构随着技术的革新不断地更新其内容,软体架构建立于当前技术和一些基本原则的基础之上。
基本原则
分层原则
分层是为了降低软体深度複杂性而使用的关键思想,就像社会有了阶级一样,软体有了层次结构。
模组化原则
模组化是化解软体广度複杂的必然手段,模组化的目的就是让软体分工。
接口实现分离原则随着软体模组化的不断深入改进,面向接口编程而不是面向实现编程可以让複杂度日趋增高的软体降低模组之间的耦合度,从而让各模组更轻鬆改进。从这个原则出发,软体也从微观进行了细緻的规范化。
还有两个比较小但很重要的原则
细节隐藏原则
很显然把複杂问题简化,把难看的细节隐去,能让软体结构更清晰。其实这个原则使用很普遍,java/c++语言中的封装原则以及设计模式中的Facade(外观)模式就很能体现这个原则的精神。
依赖倒置原则
随着软体结构的进一步发展,层与层之间、模组与模组之间的依赖逐渐加深,而层、模组的动态可插拔要求不端增大。依赖倒置原则可看视为接口实现分离原则的深化,根据此原则的精神,软体进入了工具时代。这个原则有点类似于知名的好莱坞法则Don't call us, we'll call you。
以上这些原则奠定了我们的软体架构的价值指标。但软体架构毕竟是建立在当前技术之上的。而每一代技术都有架构模式。过去的不再说了,让我们就来看一下当前流行的技术,以及我们能採用的架构。
因为面向对象是当前最流行开发技术,且设计模式的大量使用使面向对象的走向成熟,而资料库是当前最有效的存储结构、web界面是当前最流行的用户接口,所以当前最典型的三层次架构就架构在以上几项技术的基础之上,用资料库作存储层、用面向对象来实现业务层、用web来作为用户接口层。我们从三层次架构谈起
因为面向对象技术和资料库技术不适配,所以在标準三层次架构的基础上,我们增加了数据持久层,来管理O-R双向映射,但目前一直没有最理想的实现技术。cmp和entity bean技术因为其实现複杂,功能前景有限,已接近被淘汰的边缘。JDO及hibernate作为o-r映射的后期之秀,尤其是hibernate,功能相当完备。推荐作为持久层的首选
在业务层,因为当前业务日趋负载,且变动频繁,所以我们必须有足够敏捷的技术来保证我们的适应变化的能力,在标準j2ee系统中session bean负责业务处理,且有不错的性能表现,但採用ejb系统对业务架构模式改变太大,且其複杂而昂贵,业务代码移植性差。而spring 作为一个bean配置的轻量级架构,漂亮的IOC模式实现,对业务架构影响小,所以推荐作为中间层业务框架。
在用户结构层,虽然servlet/jsp/jstl/javaBean 能够实现MVC架构,但终究过于粗糙。struts对MVC架构的实现就比较完美,Taperstry也极好地实现MVC架构,且採用基于事件的方式,非常诱人,惜其不够成熟,我们仍旧推荐struts作为用户接口层基础架构。
因为业务层是三层次架构中最有决定意义的,所以让我们回到业务层细緻地分析一下,在複杂的业务我们常常需要以下基础服务的一种或几种事务一致 性服务acid(tool:jta/jts)、并发加锁服务concurrent&&lock、池化管理服务cache、访问控制服务(tool:jaas)、流程控制服务workflow、动态实现服务IOC,串列化讯息服务(tool:jms)、负载平衡服务blance等。如果我们不採用重量级套用伺服器(如weblogic,websphere,jboss等)及重量级组件(EJB),我们必须自己实现其中一些服务。虽然我们大 多情况下,不需要所有这些服务,但实现起来却非易事。幸运的是我们有大量的开源实现代码,但採用开原始码却常常是件不轻鬆的事。
随着xml作为结构化信息传输和存储地位日渐重要,一些xml文档操作工具(DOM,Digester,SAX等)的使用愈发重要,而随着 xml schema的java binding工具(jaxb,xmlbean等)工具的成熟,採用xml schema来设计xml文档格式,然后採用java binding来生成java bean 会成为主要编程模式,而这又进一步使数据中心向xml转移,使在中小数据量上,愈发倾向于以xquery为查询语言的xml资料库。最.近还有一个趋势, microsoft,ibm等纷纷大量开发中间软体如(microsoft office之infopath),可以直接从xml schema 生成录入页面等非常实用的功能。还有web service 的广泛套用,都将对软体的架构有非常重大的影响。至于面向服务架构(SOA)前景如何,三层次架构什幺时候走入历史,还很难定论。
aop的发展也会对软体架构有很深的影响,但在面向对象架构里,无论aspectJ还是jboss-aop抑是aspectWerks、 nanning都有其自身的严重问题维护性很差,所以说它将很难走远。也许作为一个很好的思想,它将在web service里大展身手。
rdf,owl作为w3c语义模型的标誌性的语言,也很难想像能在当前业务架构发挥太大影响。但如果真如它所声称那样,广泛地改变着信息的结构。那幺对软体架构也会有深远影响。
培训机构
目前培训机构遍地都是,IT人才一批又一批被培养出来,工作需求较小