3

次のダーツ コードは、Java の実装に比べて非常に遅いです。

//test.dart
import 'dart:io';
void main(){
for(int i = 0; i < 1 << 25;i++){
   stdout.write(i); // or directly print(i);
 }
  stdout.close();
}

Java バージョン:

//Test.java
import java.io.*;
public class Test{
public static void main(String[]args)throws Exception {
    try{
        PrintWriter out = new PrintWriter(System.out);
        for(int i = 0;i < 1 << 25; i++){
            out.print(i);
        }
        out.close();
    }catch(Exception e){}
  }
}

$ time Java テスト > /dev/null

real    0m6.421s
user    0m0.046s
sys     0m0.031s

$ time dart Test.dart > /dev/null

real    0m51.978s
user    0m0.015s
sys     0m0.078s

Dartではデフォルトでstdout/print()はバッファリングされていませんか? JavaのPrintWriterのようなものはありますか? ありがとう。(更新: vm をウォームアップした後、stdout は java よりも 2 倍遅くなります)

real 0m15.497s   
user 0m0.046s   
sys 0m0.047s

================================================== =============================

2013 年 9 月 30 日更新

さらに比較を行うために、dart と Java コードの両方にカスタム バッファを実装しました。結果は次のようになります。

//test.dart
final int SIZE = 8192;
final int NUM = 1 << 25;
void main(){
  List<int> content = new List(SIZE);
  content.fillRange(0, SIZE, 0);
  for(int i = 0; i < NUM;i++){
    if(i % SIZE == 0 && i > 0)
        print(content);
    content[i % SIZE] = i;
  }
  if (NUM % SIZE ==0)
    print(content);
  else
    print(content.sublist(0, NUM % SIZE));
}

Java バージョン:

//Test.java
import java.util.Arrays;
public class Test{
public static final int SIZE = 8192;
public static final int NUM = 1 << 25;
public static void main(String[]args)throws Exception {
    try{
        int[] buf = new int[SIZE];
        for(int i = 0;i < NUM; i++){
            if(i % SIZE == 0 && i > 0)
                System.out.print(Arrays.toString(buf));
            buf[i % SIZE] = i;              
        }
        if(NUM % SIZE == 0)
            System.out.print(Arrays.toString(buf));
        else
        {
            int[] newbuf = new int[NUM % SIZE];
            newbuf = Arrays.copyOfRange(buf, 0, (NUM % SIZE));
            System.out.print(Arrays.toString(newbuf));
        }
        }catch(Exception e){}
    }
}

$ time Java テスト > /dev/null

real    0m7.397s
user    0m0.031s
sys     0m0.031s

$ time dart test.dart > /dev/null

real    0m22.406s
user    0m0.015s
sys     0m0.062s

ご覧のとおり、dart はまだ java よりも 3 倍遅いです。

4

1 に答える 1

1

コードが VM によって最適化されていない可能性があります。「頻繁に」使用される関数のみがコンパイルされ、ネイティブ コードとして実行されます。通常、このようなベンチマークでは、テストされたコードを関数に入れてウォームアップを実行する必要があります。例えば:

//test.dart
import 'dart:io';
void f(nb_shift) {
for(int i = 0; i < 1 << nb_shift;i++){
   stdout.write(i); // or directly print(i);
 }
}

void main(){
  //warm up:
  f(3);
  // the test
  f(25);
  stdout.close();
}

ニコラス

于 2013-09-30T20:18:36.187 に答える