C言語関数:clock





C言語のページでは、次の内容を解説しております。
C言語の入門講座  C言語の文法を中心に、基本的な関数などの解説をしています。
C言語ケーススタディ  C言語での実践的なプログラミングについて解説をしています。
C言語の関数リファレンス  C言語で用意されている関数を解説しています。
C言語で3次元動画プログラム  C言語で3次元タートルグラフィックを使用した3次元の動画プログラムの作成例です。
C言語の検定試験  C言語の文法に関する検定試験を実施することができます。
C言語でゲーム作成  C言語を使用したゲームの作り方を解説したページも用意しております。



2014年10月より個人の方を対象に、Study C無料提供を開始しました。
C言語を勉強中の方は、学習・教育に最適なC言語インタープリタのStudy Cを使ってみてください(個人の方は無料です)。
大学・高専・高校などの教育機関での採用実績も多数あるロングセラー商品Study Cが、個人向けに無料提供を始めました。
インタープリタの手軽さに加え、ゲームや3Dタートルグラフィックで楽しく勉強したりと、C言語の学習を協力にサポートします。
ブロック崩しゲーム 3Dツリー クリスマスツリー
また、このようなボタンの用意されているページでは、掲載しているプログラムをStudy Cに直接ロードし実行したりすることができます。
Study Cにロードする Study Cにロードし編集する Study Cにロードし実行する
Study C無料利用についての詳細は、このページを参照してください。




■clock
プログラム開始からの時刻を取得

【分類】
時間関数

【書式】
long clock(void);

【パラメータの型と説明】
なし

【機能説明】
プログラムの実行を開始してから経過した時間(ミリ秒単位)を返します。
※ミリ秒単位の精度で計測できるわけではありません。

free()関数の使用例です。

#include <stdio.h>

main()
{
        long    start;
        int     i, sum;

        start = clock();
        for (i = 1; i < 10000; i++)
        {
                sum += i;
        }
        printf("経過時間:%ldミリ秒\n", clock() - start);
}

実行結果は以下になります(値は実行環境によって変わってきます)。

経過時間:15ミリ秒

1.clock()関数でループ開始前の経過時刻をstart変数に記録します。
2.forループで1から10000までの合計を計算します(ダミーの処理です)。
3.再び、clock()関数を呼び出しstart変数の値を減算します。
printf()関数でループ処理にかかった時間をミリ秒単位(ミリ秒単位の精度ではありません)で表示します。

time()関数でも、同じように開始前と開始後で返される値を使って実行時間を計測することができます。 しかし、1秒単位でしか計測することができません。

これ以外にclock()関数はゲームなどで動きの早さを調節したりすることにも使用されます。

【参照関数】
time