编程语言

img abcdhy

Java为什么不支持"无符号型基本数据"---一个无意中的发现!!

发表于2004/9/28 0:29:00  4207人阅读

分类: Java

我一直学习 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 内置支持    无符号基本数据类型!

不知各位大侠有什么看法?望不吝赐教!

阅读全文
0 0

相关文章推荐

img
取 消
img