开发java应用,听到的最多的一句话就是“跨平台”,那么现在小声的问一句,你开发的系统真的能跨平台吗?
以我的拙见,所谓的跨平台,包含五方面的内容:
一、跨应用服务器
二、跨数据库
三、跨操作系统
四、跨浏览器
五、多语言支持
下面分别来说一下。
■跨应用服务器
这一点,看起来好像有些多余,java的口号之一不就是“一次编译,到外运行”嘛,可实际经验告诉我们,这仅仅是一个口号而已。实际中是“一次编译,到处调试”。为什么会这样?从应用服务器来说,各个产品或多或少都在标准的java规范之上进行了一些拓展,小规模的应用开发,多以tomcat为基准;大规模的应用,多以weblogic/websphere为基准。
那么开发完成的应用,可否在所有的应用服务器上正常部署呢?答案是否定的。在tomcat5上部署没问题,在tomcat4上却可能有问题;在tomcat5/4上没问题,却可能在resin/jetty/weblogic/websphere上有问题。在我的经历中,在resin/jetty/weblogic为基准进行开发的应用,部署到tomcat上基本上没什么问题。但是以tomcat为基准的应用,部署到其他应用服务器中,却可能出现各种各样的问题。这与tomcat本身的定位和开发方式有关,它更像是一个学术产品,而不是一个商业产品。
小型的应用,我偏好resin,它的速度、稳定性、兼容性、中文处理,都是非常不错的。相比而言,以“纯java、快速”著称的jetty,就不太令人满意。jetty的4/5/6各个版本中,对session的存放位置、web.xml的标准、struts的plugin的支持、log4j的处理,都各不相同。在最新的jetty6中,竟然会要命地“不能使用session.validate()”方法,一使用此方法之后,就无法再使用set/getAttribute了。
也曾经在将一个应用转移到websphere5上时,费劲周折。这个应用跑在其他应用服务器上都没问题,但是一部署到ws5上,就无法正常加载struts的配置文件。本以为是struts配置文件写得有问题,但即便把所有的action/form配置均去掉,只保留一个空的配置文件,也无法正常启动。最后实在无法,只能乱碰运气,考虑是否是struts的几个jar包版本有问题,经检查,发现应用中使用的是struts1.2的jar包,换成struts1.1的jar包,再启动后就一切正常。这样的问题,可真的是折磨人呢。
所以,我认为跨应用服务器是很重要的。你不能告诉客户,俺们的系统只能跑在tomcat下面,至于您花重金购买的weblogic/websphere,对不起,我们暂时还不支持。客户会吐血的。
■跨数据库
经常看到某大公司产品,要求必须使用oracle或者sqlserver数据库,你想换个数据库来部署?没门,人家说了,我们的产品只支持这一种数据库,你就老实的用吧。但对于客户方来说,为了减少投资,并且保证内部系统尽可能使用同一种数据库以减少维护成本(总不能请一个oracle DBA,再请一个sqlserver DBA吧?),总会希望新系统使用的数据库是以前用过的吧。
现在有了hibernate,在此基础上开发的应用,基本上是能满足跨数据库要求的,个人认为这是hibernate最大的亮点。但也要注意,在开发中尽可能考虑到不同数据库的特性。诸如sqlserver的text/image字段上不能查distinct,oracle内的各种对象名称长度不得超过30等,尽量不要调用数据库的内部特性(如存储过程、视图等)
■跨操作系统
这一点,貌似没有什么可说的,很少有开发出的系统只能部署在一种操作系统上的。不过有一点也要注意,如果系统中某些功能依赖于通过JNI来调用windows本地组件的话,比如打印、word/excel操作,或与只能运行在windows下的报表组件(如国内的数巨报表、如意报表)集成的话。
■跨浏览器
窃以为,如果只是做国内的应用,这一点倒不重要,就以IE为标准来开发也未尝不可。
PS:完全支持IE也不是一件容易的事情,IE5/6本身就有不少的差异。
但如果产品本身想立足于世界,想与国外产品竞争,对浏览器的全面支持也必不可少。至少应该同时支持ie和firefox吧,如果对自身严格要求的话,我认为应以opera为标准,opera对html/css/javascript的标准是实现和支持得最好的浏览器。
■多语言支持
如果您的产品只想在中国卖,根本就不考虑世界市场,那这一条就pass好了。
但对于面向全球市场的产品来说,在开发之初不考虑多语言支持(不是没有啊),等有一天,公司老板决定要向全球推出该产品的时候,嗯,才发现,要对系统进行伤筋动骨的大手术,就等着哭吧。
分享到:
- 2006-10-19 11:23
- 浏览 13199
- 评论(25)
- 论坛回复 / 浏览 (23 / 20841)
- 查看更多
相关推荐
Java 跨平台性是 Java 语言的一项重要特性,它允许 Java 程序在不同的操作系统平台上运行,而不需要重新编译。这种跨平台性是通过 Java 虚拟机(JVM)来实现的。 Java 跨平台性的定义是指 Java 程序可以在不同的...
QGIS是一个开源的、跨平台的地理信息系统(GIS)软件,用于浏览、编辑和分析地理空间数据,提供了一套丰富的功能,包括地图制作、空间分析、数据管理等。QGIS可以在Windows、Mac OS和Linux等操作系统上运行。 QGIS的...
VS2019 跨平台使用技巧的主要目的是为了在 Windows 上编辑代码,然后通过网口上传到另一个 Linux 系统上,并进行编辑的过程。以下是 VS2019 跨平台使用技巧的详细说明: 一、Linux 远程开发——传统的 sln 项目 1....
Java语言之所以能够实现跨平台,关键在于其编译后的字节码(Bytecode)可以在各种操作系统上的JVM中运行。无论是在Windows还是Linux环境下,只要安装了兼容版本的JVM,就可以执行相同的Java程序。因此,基于Java技术...
3. **选择跨平台的第三方软件和数据库**:对于数据库需求,可以选择MySQL、PostgreSQL等跨平台数据库系统,这些系统在多种操作系统上都有良好的支持。 4. **使用跨平台的第三方库**:如OpenGL库用于图形渲染,...
跨平台开发是软件开发领域中的一个重要方面,它允许开发者使用统一的代码库来构建能在多种操作系统上运行的应用程序,这不仅可以减少开发和维护成本,还能扩大应用的潜在用户基础。 书中首先讨论了Netscape浏览器在...
本书《C/C++编写跨平台程序:实践篇》主要面向已经具备一定C/C++基础的读者群体,旨在教授如何使用C/C++这一强大的编程语言来编写可以在多个操作系统上运行的跨平台程序。跨平台编程不仅需要对语言有深入理解,还要...
Go 语言跨平台 GUI 自动化系统, 控制键盘、鼠标、位图和读取屏幕, 窗口句柄以及全局事件监听 Go 语言跨平台 GUI 自动化系统, 控制键盘、鼠标、位图和读取屏幕, 窗口句柄以及全局事件监听 Go 语言跨平台 GUI 自动化...
【标题】中的“基于ASP.net的跨平台智能云管理系统源码”表明这是一个使用ASP.NET技术开发的、具备跨平台特性的智能云管理系统的源代码集合。ASP.NET是微软公司推出的一种用于构建Web应用程序的框架,它基于.NET ...
金盾跨平台视频加密系统2021是一款专为个人和企业设计的高效视频保护工具。该系统的主要功能是确保视频内容的安全性,防止未经授权的访问、复制或传播。通过强大的加密技术,用户可以轻松地对自有的视频资料进行加密...
对于编程语言而言,跨平台能力意味着开发者编写的程序无需修改或只需少量修改就能在不同的操作系统或硬件平台上运行。 #### 平台与指令集的关系 一个平台通常指特定的操作系统与CPU的组合。不同类型的CPU有着各自...
基于C++实现的支持多操作系统,跨平台,跨协议,跨互联网的远程控制、远程桌面软件源代码 一个跨平台,支持多协议的远程控制软件。 能让你在任何地方使用任何设备和系统通过任意方式远程管理任意设备和系统。 它包括...
标题中的“国产的跨平台的开源GUI框架”指的是由中国开发者创建的一种图形用户界面(GUI)开发框架,它具有跨平台的特性,可以在多种操作系统上运行,如Windows、Linux、macOS等。这样的框架通常采用开源许可证,...
《wxWidgets跨平台程序开发》系统地介绍了wxWidgets及其跨平台程序开发。全书共有20章,第·1·章简要介绍了·wxWidgets·的发展历史和框架结构,第2章介绍了wxWidgets的程序框架及其实现,第3章深入剖析了wxWidgets...
标题中的“C#跨平台UI框架,支持Windows、Mac、Linux,支持国产Linux”指的是一种使用C#语言开发的用户界面(UI)框架,它能够兼容多种操作系统平台,包括微软的Windows、苹果的MacOS以及开源的Linux系统,特别地,...
在现代软件开发领域,跨平台开发成为了一种趋势,它允许开发者编写的代码可以在多种操作系统上运行,无需进行大量的修改或重写。C++作为一种强大的编程语言,因其高效、灵活以及对底层硬件的直接控制能力而备受青睐...
这一特性主要得益于Java的跨平台性,使得开发者可以在不同的操作系统上编译和运行相同的代码。下面我们将详细探讨Java跨平台的原理。 #### 1. Java的字节码与JVM Java程序在编译阶段不会直接编译成本地机器码,...
QGIS是一个开源的、跨平台的地理信息系统(GIS)软件,用于浏览、编辑和分析地理空间数据,提供了一套丰富的功能,包括地图制作、空间分析、数据管理等。QGIS可以在Windows、Mac OS和Linux等操作系统上运行。 QGIS的...
跨平台进程间通信(IPC,Inter-Process Communication)是计算机技术中的一个重要概念,它允许不同进程之间共享数据、协调工作,实现系统资源的有效利用。在标题中提到的“跨平台进程间通信源码”可能是一个软件库...
Rose 是基于SDL的跨平台C SDK,它向应用程序提供更高级接口。 特色 基于SDL实现跨平台,支持的平台包括Windows、iOS、Android、Mac OS X、Linux。 针对最终用户,做到了跨平台,在任何平台...