質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

Q&A

解決済

2回答

4799閲覧

処理時間の計測方法について

jaxxaxa

総合スコア10

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

0グッド

0クリップ

投稿2020/05/15 09:00

表題の件で、少し困っているので質問させていただきます。

処理時間の計測の記事を参考にして処理時間を計測するソースを書きました。

処理時間の出力結果はコンソール上に出ているのでそこは問題ないのですが
0ミリ秒と出ており、正しいのかどうか不明です。

ミリ秒だとわかりにくいので秒に変換してコンソール上に結果を出すようにしています。

実行環境は
Java8
Eclipse 4.6です。

以下簡単なソースコードです。

java

1import java.util.concurrent.TimeUnit; 2 3public class Toitoi { 4 public static void main(String[] args) throws Exception { 5 6 long start = System.currentTimeMillis(); 7 8 StringBuilder build = new StringBuilder(); 9 build.append("おごと"); 10 build.append("~~~"); 11 build.append("by"); 12 build.append("豊田 一幸"); 13 14 try { 15 System.out.println(build); 16 17 long end = System.currentTimeMillis(); 18 System.out.println(TimeUnit.MILLISECONDS.toSeconds(end - start) + "ms"); 19 } catch (Exception e) { 20 e.printStackTrace(); 21 } 22 } 23}

よろしくお願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2020/05/15 09:23

もっと時間のかかる処理を試されたほうが良いのでは。 100万回ループするとか。大袈裟なくらいがちょうどいいですよ。
dodox86

2020/05/15 09:34

普通のPCなら1ミリ秒でも結構な量のコードを実行することができるので、コードによっては差が0ミリ秒でもおかしくないです。秒単位にしてしまったら分からないでしょうね。m.ts10806さんにコメントいただいたように、何万回ループするとか、何らかのWAITを入れて試してみると良いと思います。
guest

回答2

0

ベストアンサー

toSecondsなど単位の細かいほうから荒い方への変換(今回はミリ秒から秒への変換)は整数位未満は切り捨てが発生します。1000ms以上経過していなければ出力は0です。

列挙TimeUnit | Java(tm) Platform Standard Edition 8

正しく計測できたかどうかはstartとendの差を直に参照してみてください。
これぐらいの処理では1msかからないかもしれませんが。

ミリ秒だとわかりにくいので秒に変換してコンソール上に結果を出すようにしています。

処理速度計測の世界ではミリ秒マイクロ秒の世界です。この機にぜひミリ秒に慣れてください。

投稿2020/05/15 09:38

hope_mucci

総合スコア4447

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

jaxxaxa

2020/05/17 01:32

ご回答ありがとうございます。 処理内容やループ回数をもっとたくさん増やすとか負荷量など上げないと そもそも1msにさえ届かないことも全然あるのですね。。 処理速度の単位や感覚が全然つかめなかったので、今回を機に慣れるようやってみます。
guest

0

既にあるように、toSeconds不要だと思います。
ついで言うと提示の処理だけだと1ミリ秒すら届きません。

下記で2msです。

java

1 long start = System.currentTimeMillis(); 2 3 for(int i = 0;i<1000000;i++){ 4 5 } 6 long end = System.currentTimeMillis(); 7System.out.println((end - start) + "ms");

「とりあえずきちんと結果だけ出したい」のでしたら
Thread.sleep()で制御するのが妥当でしょうね。

java

1 long start = System.currentTimeMillis(); 2 3 Thread.sleep(1000); 4 long end = System.currentTimeMillis(); 5System.out.println((end - start) + "ms");

これも通常はミリ秒で指定します。

というか、ご自身のコードmsって書かれていますが、これは「ミリセカンド(ミリ秒」です。
toSeconds()したのであればmがあっては出力結果が正しくないです。

投稿2020/05/15 12:41

m.ts10806

総合スコア80875

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問