`
zhouxing
  • 浏览: 207424 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

.NET和J2EE该相互学习什么?

阅读更多
2007-11-19 来自:conanpaul  
前言] 写这篇Post源于我既做过.NET开发又做过J2EE开发的经历。在这样的转变过程中,我对单一平台开发所带来的思维局限性有了很多清晰却零散的想法。在看了振河兄的页面间传递变量的方法及使用范围的讨论之后,我更能体会到在不同的平台进行开发,思维方式会是如此之不同,原来那些零散的想法也随之不断在脑海中涌现,让我有了写下这篇Post的冲动。其实我一直都在宣扬一种观点:技术之间是相通的,精于触类旁通,善于联想是我们程序员应有的优势。我们在专注.NET技术的时候,不妨在工作间隙休息的时候看看.NET外面的世界。

  提到.NET和J2EE,一般都会想到它们之间兵戎相见,水火不容的关系,毕竟两者都在努力地去虏获程序员的青睐,占领更多的市场份额。我无意去鼓吹.NET是如何如何之强大,J2EE是如何如何的成熟,也无意去探究NHibernate,Spring.NET等等Project的起源,只想从一个程序员的角度去看待两者在互相竞争的过程当中到底相互借鉴了什么,同时探讨一下同时了解两个领域知识的必要性。好,让我们言归正传。

  还记得2003年初,我到了DELL公司实习,所承担的工作任务就是建立一个Web Application供多个有密切联系的部门使用,以提高部门间的协作程度。在选择用什么技术来做这个Web Application的时候,我放弃了比较熟悉的ASP,进而选择了ASP.NET。正是做这个Project,我跟ASP.NET乃至.NET结下了不解之缘。当时第一次接触到ASP.NET,第一个感觉就是,它比ASP好多了,再也不用像写ASP那样在HTML嵌套着一堆堆的Scriptlet,动态内容的呈现都包含在一个个方法中,如Page.OnInit()和Page.OnLoad()等等,这些方法让我看到Client端JS方法的影子。在开发ASP.NET页面的过程中,我需要做的就是在页面中引入不同的Web Control或者是HTML Control,这些Controls与HTML标签是何等的类似,除了它有ASP的prefix和那时看起来如Magic一般的runat="server"。这样的相似性让熟悉HTML和JS的我很快掌握了ASP.NET的基本应用,而我也以极高的效率完成了公司分配给我的任务,尽管我对诸如Request、Response、Session和Application这样的对象并不是十分了解。ASP.NET所带来的进步是革命性的,难怪有朋友认为ASP.NET是.NET家族中最为成功的产品了。我当时只是拿ASP.NET来跟ASP作对比,其优越性自然显露无遗,尤其是在控件设计方面的优势。事实上直到后来进入J2EE的开发领域,我依然对ASP.NET的开发方式赞赏有加。Microsoft在技术的创新上一直秉持削弱领域开发特性的原则,让开发人员能够在不同的开发领域中都可以轻松上手,游刃有余。ASP.NET的出现带来了WebForm,而在桌面程序开发中则有WinForm,两者相通的地方随处可见,这让原有的桌面程序开发人员可以平滑的过渡到Web Application开发中来; ASP.NET对于控件在设计以及使用上的支持堪称完美,也为网页设计人员进入ASP.NET开发领域扫除了不少的障碍。反观J2EE领域,做Swing开发的人员,如果要学习Web的开发,原有的知识几乎无用武之地了。在这个人气就是财富的年代,在一定层面上求同存异,让开发人员能够一通百通,无疑是一个十分明智的做法。J2EE领域也开始意识到了这一点,将Swing概念应用到Web开发的Wicket Framwork的发布着实是一个极大的进步啊。J2EE在降低Web开发的难度,吸引入门级开发人员方面需要向.NET好好请教一番了。

  好,个人经历接着说。2003年底,我进入了一家软件公司从事J2EE的开发工作。当时公司技术部门负责人在面试我的时候提到了我缺乏J2EE的开发经验的问题,我信心满满的告诉他,我做过.NET的项目,而.NET和J2EE都是专注在企业级应用上的,因此肯定会很快上手,不会有什么问题。然而后来的工作证明了平台之间的差异性是很大的,从.NET过渡到J2EE并不是一件轻松的事情。没有了熟悉的Web Control,取而代之的是简陋的Tag Library; 没有了简单易用的Event-Driven的方法,呈现眼前的是doGet、doPost、doHead和service这样看似丑陋的面孔。蜕变的过程是痛苦的,但是蜕变带来了进化。开发方式的改变让我可以从一个更加深入的层面去看待Web开发,而我开始重新认识Web Application。Web开发的复杂性在很大程度上源于Http是一个无状态的连接协议,Web Server不管你是Michael,还是Jordon,只要你在浏览器上使用了相同的URL,就会得到相同的资源。在这里,你必须清楚URL到底是什么的缩写。也许你会站出来反驳我刚才所说的结论,但是这种情况在只有静态HTML网页的年代是绝对正确的。随着时代的发展,资源已经不再局限于静态的HTML网页,随之出现了所谓的动态网页。这里的动态不是指充满Flash动画的网页,而是指网页的内容会根据不同的Request而发生变化。虽然Web的内容开始个性化了,但是仍然没有脱离Client发送Request,Server返回Response这样的模式。由于Http是一个无状态的连接协议,为了能够识别用户访问同一资源的状态,在J2EE的世界里,我们就得从Request、Response和Session这样的对象入手,控制这些对象的Life Cycle。因此,我们哪怕要进行最为简单的Web应用程序,都必须对Request、Response和Session这样的对象有充分的了解。关注这些基本的对象,让我们对于应用程序的Flow有更为准确的把握,能够更好地进行模块地划分,便于开发人员进行协作。然而在.NET的世界里,对Request和Session这样的对象关注远不如对Page的关注,从振河兄的Post就可见一斑了。ASP.NET开发降低了开发难度,却在一定程度上阻碍了开发人员对Web Application的整体把握,正如春鱼兄的Feedback中提到的,过分纠缠页面之间关系,“不利于系统整体架构的良好设计”。J2EE的应用程序可以让程序员在Web Application的整体架构上有一个很好的体现,.NET还是得好好努力啊!建议.NET的程序员能够尝试着利用J2EE的技术来开发一个简单的Web Application,我相信这样的一个过程会让你对Web开发有进一步的认识。
分享到:
评论

相关推荐

    J2EE和.NET二者的区别

    J2EE和.NET是两种不同的软件开发平台,它们之间有着明显的差异,但同时也存在着一些相互借鉴和共荣的方面。 首先,从开发角度来看,J2EE和.NET都有其独特的设计理念和架构风格。J2EE是基于Java语言的企业级应用平台...

    使用IIOP.NET使用.NET和J2EE构建分布式对象系统

    3. "iiopnetdemoonly.zip" 提供的是IIOP.NET的演示程序,用于展示如何在实际场景中使用该库,这对于初学者快速理解和学习IIOP.NET的用法非常有帮助。 在本文中,读者可以期待学习到以下内容: - IIOP协议的基本原理...

    《J2EE全实例教程》

    【标题】《J2EE全实例教程》是一本专为初学者设计的全面解析...书中的"200631111829117_zasp.net"可能是一个示例项目或案例,可能涵盖了ASP.NET与J2EE的交互或比较,有助于读者拓宽视野,理解跨平台开发的差异和共性。

    【中文】【J2EE设计模式】【(PDF) 】

    在J2EE中,该模式可用于实现可插拔的业务逻辑,允许用户根据不同的需求选择不同的处理策略。 ### J2EE设计模式的应用案例 以Singleton模式为例,在J2EE环境中创建数据库连接池时,可以使用Singleton模式来确保整个...

    Web整体测试与性能指标(学习).pdf

    对于B/S架构,无论是.NET还是J2EE,通常涉及界面层、业务逻辑层和数据层。 性能测试不是仅仅运行测试工具证明产品达到性能要求,而是要发现并修复性能缺陷。下面是一些通用的性能指标: 1. **ProcessorTime**: ...

    NET程序设计全接触C#描述

    - **第3章**:介绍.NET开发中常用的基础技术,如XML(扩展标记语言)和SOAP(简单对象访问协议),这些是.NET架构的重要组成部分,为后续章节的学习奠定基础。 ##### 第二部分:应用篇 这部分侧重于实践操作,通过...

    C#2008入门指南

    "Java培训 J2EE培训 DOTNET培训 - 51培训网.url"则可能提供了Java和.NET的相关培训课程,对于想要深入某一领域或者转行的开发者来说,参加专业培训是个不错的选择。 总之,C#2008是一个强大且现代的编程语言,掌握...

    delphi_2005_reviewers_guide

    - **J2EE 和 CORBA 至 .NET 的集成**:通过Janeva插件,实现了Java和.NET平台之间的互操作性。 - **用户可选文件编码**:支持不同的文件编码格式,增强了对非英语字符集的支持。 - **VCL for .NET**:Delphi 2005...

    计算机科学与技术专业主要课程.pdf

    26. .Net平台应用技术(.Net Platform Application Technology):.Net平台应用技术课程讲解微软.NET平台下的开发技术,如***、C#和***等。 27. 人机交互界面设计(Design of Human and Computer Interaction ...

    Oracle.Database.11g.New.Features.for.Administrators.Exam.Guide

    - **加入学习小组或社区**:与其他备考者交流心得,分享资源和经验,相互激励和支持。 通过以上方法的综合运用,考生可以有效地准备OCP Oracle Database 11g: New Features for Administrators考试,提高通过率。 ...

    (shang硅gu)Spring Boot核心技术-笔记-pdf版.pdf

    Spring Boot是Java开发中的一个核心框架,它旨在简化Spring应用的初始搭建以及开发过程。...通过深入学习和实践,开发者可以更好地掌握Spring Boot的核心技术和最佳实践,从而提高开发效率和应用质量。

    UML基础: 统一建模语言简介

    UML的成功在于其与特定编程语言无关,这使得它在J2EE和.NET等平台中广泛应用。同时,UML并非一种方法学,而是一种语言,因此可以灵活适应各种公司的工作流程,不强求特定的工作产品或“工件”。UML的核心在于它的...

    TongWeb7.0.zip

    【TongWeb7.0.zip】是一...综上所述,【TongWeb7.0.zip】提供的内容涵盖了TongWeb7.0的安装、授权、使用和学习的全过程,对于需要在Linux环境中部署和管理Java应用的企业和个人,这款中间件产品是一个值得考虑的选择。

    The.Art.of.Agile.Development

    通过有效的沟通、共同的目标设定和相互尊重,可以显著提升团队效率和成员满意度。 ### 附加资源 此外,本书还提供了丰富的附加资源,包括O'Reilly出版社的相关书籍推荐、在线资源链接、会议信息以及Safari ...

    系统架构设计师教程6-21章

    3. **第10章 - 构件平台与典型架构**:本章探讨了构件平台的作用,如J2EE、.NET等,以及这些平台支持的不同架构模式,如三层架构、微服务架构等,帮助设计师选择合适的架构策略。 4. **第8章 - XML技术**:XML作为...

    二十三种设计模式【PDF版】

    些好象和 J2EE .Net 等技术也无关! 实际上,GoF 的设计模式并不是一种具体"技术",它讲述的是思想,它不仅仅展示了接口或抽象类在实际案例中的灵活应用 和智慧,让你能够真正掌握接口或抽象类的应用,从而在原来的 ...

Global site tag (gtag.js) - Google Analytics