用.NET平台下的C#语言开发了比较长一段时间,最近项目开始用JAVA来开发了,本文通过自己开发过程中的一些感受说下它们在具体开发过程的不同点,由于经验知识还有限,本篇文章只能从比较表面的以及自己常用的功能点来说明我所看到的不同点。
我是用VS2008和VS2010开发.NET程序,通过MyEclipse8.5开发JAVA程序,下面从IDE、语言、插件的不同点来做下简单的说明。
IDE的不同点:
给我的第一感觉就是MyEclipse在开发过程编写查看代码也非常便利,甚至有很多VS没有的功能,下面列举自己现在遇到的一些不同点:
1、一个变量字段选中后,其他用到该字段的背景颜色自动凸显出来,方便查看有哪些地方用了这个变量,VS2010之前是没有这个功能的。
2、对于一个大括号或小括号的代码段,双击该符号后面,则自动选中括号内部的代码段,这个可以方便查看一个代码段,VS没有这样的功能。
3、MyEclipse没有像VS里的#region,#endregion一样的代码段区域,在一个方法或类里,可以#region 功能点….#endregion这样把代码片段折叠起来,MyEclipse除非用其他一些插件才能达到这个效果。
4、Ctrl+alt+t和Ctrl+alt+r快捷键,这个快捷键在MyEclipse里非常有用,可以分别快速查找工作空间里的type或者resource,可以快速模糊匹配找到文件或某个类型的文件,而VS没有找到这样的功能。
5、MyEclipse智能提醒默认比较简单,只要在输入.后才会自动提醒,可以在window->preferences->Java-Editor->Contenet Assist标签页的Auto-Activation框里的Auto activation triggers for Java设置成.abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ,这样设置后,在MyEclipse里输入任意字母就能提示了,但是它区分大小写,不像VS输入小写a也能智能提示大写A开头的变量类型等。
6、MyEclipse经常遇到编码问题,对于新手非常不便利,它分为文件打开乱码,和提交请求中文内容乱码两种情况。当工作空间包括多个项目时,有可能一个项目是用GBK编码,另外一个是UTF-8,这样就会导致单个文件乱码,设置整个工程编码在Window->Preferences->General->Workspace选择Text file encoding里的Other设置,为单独项目在Project右键Properties->Resource选择Text file encoding里的Other设置。对于JSP等提交请求内容默认编码是ISO-8859-1,也经常导致乱码,可以在windows->Preferences->general->Content Types里的Text设置不同文件的编码。但是VS没有这么多乱码问题,对新手不容易出现乱码的问题。
7、MyEclipse经常会提示内存溢出等相关内存问题,对于新手也是比较困惑的事情,往往是内存默认配置不够等造成的,修改myeclipse.ini里-vmargs下面的配置参数,比如-Xmx912m表示最大分配堆内存912M,-XX:MaxPermSize=556m表示最大分配非堆内存556M,这个可以让MyEclipse内存可能够用。但部分内存溢出,可能是JVM内存占用溢出,就需要单独设置JVM的内存参数了,在window->preferences->Java->Installed JRE里的,选中默认JDK,然后选择Edit,在Default VM Arguments里配置相关参数即可。如果跑的程序是WEB程序,可能还需要设置Tomcat的内存设置,在window->preferences->MyEclipse->Servers->Tomcat,选中对应版本的Tomcat,然后选择里面的JDK节点,在Optional Java VM arguments里设置内存参数。相对来说VS就不会有这么麻烦的处理了,一般都不用设置内存参数。
8、调试代码的时候,VS就表现出比MyEclipse更强大了,它们都可以在断点处修改已经存在的变量的值,但是VS在监控临时变量框里输入变量时同样可以智能提示自己写的代码,而MyEclipse不能自动提醒,并且VS可以拖动断点到已经运行的代码,这个功能在调试问题时是非常强大和有用的,但是MyEclipse不能拖动断点。
9、默认的Ctrl+左键点击,可以快速定位到该字段或类型的定义处, 和F3一样,但是我觉得ctrl+左键开发过程中更顺手,比VS里默认的F12快速定位会感觉更便利,而且它集成Spring后,Ctrl+左键可以选择定位到注入接口的子实现代码,这样可以很方便的查看实现代码,而VS当使用Spring.net集成时,是不提供这个功能的。
10、MyEclipse里右键-source,可以有很多比较方便的功能,比如生成getter,setter和继承接口父类方法。
11、JAVA项目是通过导入方式打开,不是通过像VS里双击.sln或.csproj文件就可以打开整个工程。但是打开一次过后,下次再打开MyEclipse,它都会自动加载已经打开过的项目。而VS是每次只能打开一个解决方案,解决方案里包括不同项目。如果新增了解决方案,下次就需要单独打开了。
12、MyEclipse导入新项目,如果JRE版本不一样,需要选择使用本地JRE版本,项目右键->Build Path->Configure Build Path->Libraries->Java Build Path里修改JRE版本,但有时还会出现编译问题,原因是没有选择编译的JDK版本,项目右键->Build Path->Configure Build Path->Java Compiler里修改Compiler compliance level。对于VS,高版本代码打开低版本代码,会自动升级,或者手工选择在.NET哪个版本下编译,会比较方便。
13、MyEclipse双击代码编辑框里文件的Tab栏,就可以切换全屏显示代码编辑块和多框显示,这点比VS更方便一点,Package Explorer框的旁边有个Link Vith Editor按钮,可以快速定位文件在包里的位置,这个也比较方便,但是VS里一个文件右键后可以直接选择打开对应的物理文件目录,在MyEclipse里没有这个功能。
语言的不同点:
Java语言和C#语言非常相似,虽然内部会有很多区别,提供的API也不一样,但开发一个具体功能点的思路常用的都差不多,由于对比较新的技术和特性开发过程中接触不多,我所遇到的不同点包括:
1、Java包的名字是和物理文件位置一一对应的, C#里命名空间可以随便写,并且编译出来的程序集也可以随便更改,可以不和命名空间保持一致,程序集和JAVA里单独打出来的jar包是差不多的意思。
2、JAVA的一个文件只能有一个公共类,而C#可以多个公共类在一个文件里。
3、如果找到一个JAR包,Java查看新jar包的方法字段描述,需要有单独的对应jar包的doc文档,才能看到接口调用参数说明,否则看起来不直观,但是如果有源码打出来的jar包,调试的时候可以方便的看到该包的源代码。.NET里只要有了dll文件,就能方便的看到方法元数据调用参数,但是看到参数详细说明,还是需要对应dll的xml文档。
4、对于WEB开发,JAVA里Filter,Servlet,Listener是很常用的,Java里的Filter可以用.NET里的module来实现一些功能,但Filter可以制定作用请求范围,module是全局控制的;Servlet相当于一个具体的handler,可以对制定请求进行处理,Listerner可以用.NET里的Application_Start里来完成一些功能,但是JAVA里集成了部分默认Listerner,它在WEB应用启动的时候就开始执行。它们的具体执行流程为:WEB启动时,Listener的ContextInitialized方法->所有Filter的Init(不管filter-mapping的值)->所有配置了load-on-startup大于等于0的Servlet的init方法(不管servlet-mapping的值),具体请求为:具体Servlet的init(只执行一次)->Filter doFilter(请求配置的filter-mapping的value)->Servlet service; 最后网站释放的执行顺序为:Filter destroy-》Listener contextDestroyed。
5、Java里的Final关键字,当给一个字段时,表示该字段不能修改,构造函数里都不能修改,这个和C#的const有点像,但是const默认是static的。和C#的readonly也比较像,但是readonly可以在构造函数里修改。当它作为一个方法的修饰符时,它类试c#的sealed类,不能重写它。
6、Java里没有静态构造函数,如果要实现一些初始化工作,需要用静态代码块,static{…},里面输入内容即可,C#只有静态构造函数的说法。
7、JAVA中有常量池概念,是和堆、栈不一样的区域,虽然和C#一样String都有字符串驻留机制,但是和.NET的又不一样了。因此java里字符串比较最好用equals比较,否则可能出问题。比如"a"+"b"字符串在常量池里,如果它们和”ab”比较将相等,但是"a"+b,b是一个变量,就将放到堆里了,如果还用==”ab”判断将返回false,所以JAVA里尽量用equals来判断字符串,但是.NET里不涉及这个问题,经过计算的字符串,==的结果也会相等。
8、Java里每个文件只要有Main方法入口,它都可以运行,而.NET里需要项目类型修改为控制台应用程序,然后有一个Main方法才能作为一个运行的载体。
9、Byte类型的数字范围不一样,Java里是-128到127,.NET是0-255,一般需要互相交换数据和处理都是转换成16进制,然后取8bit的后2个bit,这样它们的值都是一样的,方便同步加密解密或相关处理
10、Java里推荐用get,set方法来对内部变量赋值和获取值,.NET里可以用字段get,set获取,并且vs2008后可以直接get;set;的方式,借助语法糖,编译器后会自动生成等价的get,set内部字段。
11、JAVA里文件保存后默认自动编译,但是这个也得益于它把每个java文件编译成一个class文件,.NET里需要单独每次执行编译项目,因为它一个项目一个dll文件,如果保存其中一个.cs文件都执行编译,则工作量太大影响开发速度。
12、Java里List是一个接口,这个对在C#里用惯了List集合的,new List已经会报错了,而且它们的泛型也不一样,C#是CLR层的泛型支持,JAVA的泛型不是经过JVM支持的,因此性能相对没有提升。
13、JAVA里默认修饰符是包内可见(对应同一个文件夹目录,而不是项目大jar包下)的, protected的变量和方法都是包内和子类可见的,.NET里是只有自己和子类可见。.NET里类的默认修饰符是Internal,程序集内可访问。方法和字段默认为private的,和JAVA默认包内可见不一样。
插件的不同点:
1、MyEclipse自身就是一个插件,里面集成了大量开源框架,而VS是微软一个大一统的IDE,要用其他开源插件,需要单独下载和单独配置。
2、Java里实现webservice的方法很多,除了javax.jws包里只有的JAX-WS,java webservice规范自带版本,还有axis,xfire的webservice开源实现,axis包括axis1,axis2,xfire已更名为cxf了,但是各种实现方法各异,在和.NET发布的webservice互相调用时,经常遇到一些问题,总体来说Java对wsdl的格式要求更严格。
上面都是自己最近开发过程中根据自己遇到的问题分析和整理的结果,涉及的面有限,需要自己以后不断完善相关技术点,并且整理和理解的结果也可能不完全准确,如有问题,请指正。
如转载请注明来自:http://lawson.cnblogs.com/