はじめに
プログラミング言語 Go とJava C# とで整数カウントアップの反復実行時間を仲良く競い合わせてみます。コンソール出力は意外と重い処理なので、いったん素の処理でどんなものなのか検証します。
この記事内容の作業環境
Windows11 Pro 22H2
VSCode(Visual Studo Code) 1.78.2
java Eclipse Adoptium jdk-20.0.2.9-hotspot
C# 10 dotnet-sdk-6.0.404-win-x64
go version go1.19.5 windows/amd64
CPU Intel(R) Core(TM) i3-5005U 2.00 GHz
この記事内容の保証
※この記事の実行結果は参考情報です。実行環境に大きく依存します。
お題のソースコード
Java
main.java
import java.lang.System;
/**
* プログラム型
*/
class Program
{
/**
* メイン
* @param args 引数
*/
public static void main(String[] args) throws Exception
{
int countMax=0;
int count=0;
if (args.length != 1) {
countMax=0;
}
try
{
countMax=Integer.parseInt(args[0]);
}
catch (Exception e)
{
countMax=0;
}
//開始時間(ナノ秒)
long startTime = System.nanoTime();
while(count < countMax){
count+=1;
}
//終了時間(ナノ秒)
long stopTime = System.nanoTime();
long spanTime = stopTime - startTime;
System.out.println("処理回数: " + count + "回");
System.out.println("処理時間: " + (spanTime / 1000000) + "ミリ秒");
}
}
C#
main.cs
using System;
/// <summary>プログラム型</summary>
class Program
{
/// <summary>メイン</summary>
/// <param name="args">引数</param>
static void Main(string[] args)
{
int countMax=0;
int count=0;
if (args.Length != 1) {
countMax=0;
}else{
try
{
countMax=int.Parse(args[0]);
}
catch (FormatException)
{
countMax=0;
}
}
//開始時間(ミリ秒)
DateTime startTime= new DateTime();
DateTime stopTime = new DateTime();
startTime = DateTime.Now;
while(count < countMax){
count+=1;
}
//終了時間(ミリ秒)
stopTime = DateTime.Now;
TimeSpan st =stopTime-startTime;
Console.WriteLine("処理回数: " + count + "回");
Console.WriteLine("処理時間: " + st.TotalMilliseconds + "ミリ秒");
}
}
Go
count.go
package main
import (
"fmt"
"os"
"strconv"
"time"
)
// メイン
func main() {
countMax := 0
count := 0
if len(os.Args) <= 1 {
countMax = 0
} else {
var err error
countMax, err = strconv.Atoi(os.Args[1])
if err != nil {
countMax = 0
}
}
//開始時間(ナノ秒)
startTime := time.Now()
for count < countMax {
count++
}
//終了時間(ナノ秒)
stopTime := time.Now()
spanTime := stopTime.Sub(startTime)
fmt.Println("処理回数: ", count, "回")
fmt.Println("処理時間: ", int64(spanTime/time.Millisecond), "ミリ秒")
}
実行結果
Java
C:\developments\java20>java -cp . Program 4000000
処理回数: 4000000回
処理時間: 3ミリ秒
C:\developments\java20>
C#
C:\developments\cs6\HelloWorld\bin\Debug\net6.0>Count.exe 4000000
処理回数: 4000000回
処理時間: 23.1618ミリ秒
C:\developments\cs6\HelloWorld\bin\Debug\net6.0>
Go
C:\developments\go1\Count>count.exe 40
処理回数: 40 回
処理時間: 0 ミリ秒
C:\developments\go1\Count>count.exe 400
処理回数: 400 回
処理時間: 0 ミリ秒
C:\developments\go1\Count>count.exe 4000
処理回数: 4000 回
処理時間: 0 ミリ秒
C:\developments\go1\Count>count.exe 40000
処理回数: 40000 回
処理時間: 0 ミリ秒
C:\developments\go1\Count>count.exe 400000
処理回数: 400000 回
処理時間: 0 ミリ秒
C:\developments\go1\Count>count.exe 4000000
処理回数: 4000000 回
処理時間: 2 ミリ秒
C:\developments\go1\Count>count.exe 40000000
処理回数: 40000000 回
処理時間: 20 ミリ秒
C:\developments\go1\Count>count.exe 400000000
処理回数: 400000000 回
処理時間: 200 ミリ秒
C:\developments\go1\Count>count.exe 4000000000
処理回数: 4000000000 回
処理時間: 2034 ミリ秒
C:\developments\go1\Count>
実行結果まとめ
表2 整数カウントアップの反復実行時間(ミリ秒)
実行回数 | Java | C# | Go |
---|---|---|---|
40 | 0 | 6 | 0 |
400 | 0 | 6 | 0 |
4,000 | 0 | 7 | 0 |
40,000 | 0 | 6 | 0 |
400,000 | 3 | 7 | 2 |
4,000,000 | 3 | 23 | 20 |
40,000,000 | 3 | 139 | 200 |
400,000,000 | 3 | 1,341 | 2,034 |
※ナノ秒台は切り捨て
おわりに
いかがでしたでしょうか?整数カウントアップを単純にループさせているだけですので、各言語、実装によってはいろいろな差異がでるものと思われますので、この件はあくまで参考情報です。