我一直学习 Java ,我朋友学的是 C#,最近没事,我们就来试了试到底是 C# 还是 Java 虚拟机的速度快。 我写的 Java 程序如下:(程序功能:列出 200000 内的所有质数) //计算质数 public class PrimeNumber { public static void main(String args[]) { long startTime = System.currentTimeMillis(); int count = 2; System.out.print("2,3,"); boolean isPN = true; int max = 1000*200; for(int i=4;i<max+1;i++) { isPN = true; int n = (int)(i/2)+1; for(int j=2;j<n;j++) { if(i%j == 0) { isPN = false; break; } } if(isPN) { System.out.print(i+","); count++; } } long endTime = System.currentTimeMillis(); System.out.println (""); System.out.println ("共用时间:"+(endTime-startTime)+"毫秒"); System.out.println ("共找到:"+count+"个质数"); } }
我朋友写的C#程序如下: using System; class test { static void Main() { DateTime t1 = DateTime.Now; cal(200000); DateTime t2 = DateTime.Now; TimeSpan t = t2-t1; Console.WriteLine("时间为:{0} 毫秒\n",t.TotalMilliseconds.ToString()); Console.ReadLine(); } static void cal(uint x) { Console.Write("2,"); uint sum=1; for(uint a=3;a<x+1;a++) { bool flag=true; uint n = (uint)(a/2)+1; for(uint b=2;b<n;b++) { if(a%b!=0) continue; flag=false; break; } if(flag) { Console.Write(a+","); sum++; } } Console.WriteLine("\n {0} 以内共有 {1} 个质数\n",x,sum); } }
在我自己的机器上测试(机器配置:P42.4B+512M+WIN2003) Java 为 JDK1.4.2_05 C# 为 WIN2003 自带的 .net 1.1
比较结果真令人沮丧: Java 程序使用了: 13M 内存 + 22 秒的时间 C# 程序使用了: 8M 内存 + 12 秒的时间
“不会吧,SUN 怎么也是做了快10年的虚拟机了,怎么会比 MS 的 .net 虚拟机慢这么多呢?” 我不相信。于是我把自己的 Java 程序改成了 C#程序,代码如下: //计算质数 using System; class PrimeNumber { static void Main() { DateTime t1 = DateTime.Now;
int count = 2; Console.Write("2,3,"); bool isPN = true; int max = 1000*200; for(int i=4;i<max+1;i++) { isPN = true; int n = (int)(i/2)+1; for(int j=2;j<n;j++) { if(i%j == 0) { isPN = false; break; } } if(isPN) { Console.Write(i+","); count++; } } DateTime t2 = DateTime.Now; TimeSpan t = t2-t1; Console.WriteLine (""); Console.WriteLine ("共用时间:"+t.TotalMilliseconds.ToString()+"毫秒"); Console.WriteLine ("共找到:"+count+"个质数"); Console.ReadLine(); } } 这次这个程序的执行结果为: 8M 内存 + 22 秒的时间
除了内存使用多一点(这可以理解,这里使用的内存只是 JVM 使用的内存,不代表程序实际使用的内存), 在时间上 C#程序 和 Java程序 没有什么差别了。
难道是我朋友写的程序的算法好,可我怎么看,也看不出它好在哪里啊! 于是我改了一下我朋友写的程序:(只是把 uint 改成了 int 型数据)具体代码如下: using System; class test { static void Main() { DateTime t1 = DateTime.Now; cal(200000); DateTime t2 = DateTime.Now; TimeSpan t = t2-t1; Console.WriteLine("时间为:{0} 毫秒\n",t.TotalMilliseconds.ToString()); Console.ReadLine(); } static void cal(int x) { Console.Write("2,"); int sum=1; for(int a=3;a<x+1;a++) { bool flag=true; int n = (int)(a/2)+1; for(int b=2;b<n;b++) { if(a%b!=0) continue; flag=false; break; } if(flag) { Console.Write(a+","); sum++; } } Console.WriteLine("\n {0} 以内共有 {1} 个质数\n",x,sum); } }
执行结果还是: 8M 内存 + 22 秒的时间
这进一步说明,Java 和 .net 虚拟机在执行效率上基本没有差别。
最开始的两个程序产生差别的唯一原因就是: C#内置支持无符号数 Java 则只有有符号数
在只需要正数的环境下,Java 的效率下去了!
Java 为什么不内置支持 “无符号基本数据类型”呢?? 这让我们在写网络程序时, byte 是有符号数,让我们不得不小心的处理,以免出现错误。 强烈建议 Java 内置支持 无符号基本数据类型!
不知各位大侠有什么看法?望不吝赐教! 
|