実際にプログラムを作ってみよう
C++を使うとどんな書き方になるのか簡単にプログラムで書いてみましょう。
今回は時間を計測するストップウォッチをC言語とC++の両方で書いてみましょう。
先ずはC言語でストップウォッチを作ります。
Stopwatch.h
#pragma once
#include <windows.h>
// ストップウォッチ情報
struct StopwatchData
{
LARGE_INTEGER Freq; // 周波数
LARGE_INTEGER Start; // 開始時間
};
// ストップウォッチの初期化
void InitStopwatch(StopwatchData* pStopwatchData);
// ストップウォッチのリセット
void ResetStopwatch(StopwatchData* pStopwatchData);
// ストップウォッチの経過時間取得
double GetElapsedTime(StopwatchData* pStopwatchData);
Stopwatch.cpp
#include "Stopwatch.h"
// ストップウォッチの初期化
void InitStopwatch(StopwatchData* pStopwatchData)
{
QueryPerformanceFrequency(&pStopwatchData->Freq);
ResetStopwatch(pStopwatchData);
}
// ストップウォッチのリセット
void ResetStopwatch(StopwatchData* pStopwatchData)
{
QueryPerformanceCounter(&pStopwatchData->Start);
}
// ストップウォッチの経過時間の取得
double GetElapsedTime(StopwatchData* pStopwatchData)
{
LARGE_INTEGER End;
QueryPerformanceCounter(&End);
const LONGLONG TICK_DELTA = 1000000000;
const double INV_TICK_DELTA = 1.0 / (double)TICK_DELTA;
LONGLONG elapsed = (End.QuadPart - pStopwatchData->Start.QuadPart);
return (double)((elapsed * TICK_DELTA) / pStopwatchData->Freq.QuadPart) * INV_TICK_DELTA;
}
これで実際に計測をしてみます。
main.cppなど適当な箇所で下記を記載します。
#include <windows.h>
#include <stdio.h>
#include "Stopwatch.h"
int APIENTRY WinMain(HINSTANCE, HINSTANCE, LPSTR, int)
{
StopwatchData stopwatchData;
InitStopwatch(&stopwatchData);
ResetStopwatch(&stopwatchData);
// 120msの待ちを入れる
Sleep(120);
double elapsed = GetElapsedTime(&stopwatchData);
char temp[64];
sprintf_s(temp, "time:%f\n", elapsed);
OutputDebugStringA(temp);
}
・結果
time:0.120951
実行してみると出力ウィンドウに上記のような結果に大体120msの結果が出るかと思います。
この結果ならちゃんと計測できてますね。