Qtの基礎 - CUIソフトウェア
ナビゲーションに移動
検索に移動
概要
Qtは、GUIソフトウェアを開発するために使用されているが、CUIソフトウェアも開発できる。
ただし、CUIは[閉じる]ボタンのように終了する機能が無いため、ソフトウェアから適当なタイミングで閉じるようにしなければならない。
ここでは、Qtにおける基本的なCUIソフトウェアの開発手順を記載する。
CUIソフトウェアの開発手順
例えば、以下のようなCUIソフトウェアのソースコードを記述したとする。
以下のソースコードにおいて、CUIソフトウェアは、永遠に終了しないプログラムになってしまう。
なぜなら、QCoreApplication
クラスのexec
メソッドは、exit
メソッドが呼ばれるまでループし続けるからである。
int main(int argc, char * argv[])
{
QCoreApplication a(argc, argv);
int count = 1000;
while(--count)
{
printf("Count = %d\n", count);
}
return a.exec();
}
これを解決するには、主の処理が終了する時、任意の地点でexit
関数を呼び出すランナークラスを作成すればよい。
例えば、以下のようなCUIRunnerクラスを定義する。
そして、CUIRunnerクラスのrunスロット内にメイン処理を記述して、処理を終了する時にQCoreApplication
クラスのexit
メソッドを呼び出せばよい。
// CUIRunner.h
#ifndef CUIRUNNER_H
#define CUIRUNNER_H
#include <QObject>
class CUIRunner : public QObject
{
Q_OBJECT
public slots:
void run(); // runスロットメソッド内部でメイン処理を実行する
};
#endif // CUIRUNNER_H
// runメソッドの定義
#include <QCoreApplication>
#include <CUIRunner.h>
void CUIRunner::run()
{
// メイン処理
// ...略
QCoreApplication::exit(0); // 閉じる(ループから抜ける)
}
ここで重要なことは、QTimer
クラスのsingleShot
メソッドのタイムアウト時間を0に設定していることである。
このように記述することにより、ウインドウシステムの全てのイベント(描画処理等)が処理された後に、runメソッドで定義した処理が実行される。
#include <QCoreApplication>
#include <QTimer>
#include "CUIRunner.h"
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
// ランナー開始
CUIRunner runner;
QTimer::singleShot(0, &runner, SLOT(run()));
return a.exec();
}
まとめ
上記のセクションにおいて、CUIソフトウェアの開発手順について記載したが、重要なことは以下の3つである。
QApplication::exit
を呼び出すとCUIソフトウェアが終了できる。QTimer::singleShot
からランナークラスを実行する。- ランナークラスにメイン処理を記述して、任意の地点で
exit
関数を実行する。