我一直学习 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 内置支持 无符号基本数据类型!
不知各位大侠有什么看法?望不吝赐教!