한국어
Qt
 

C++ Class main함수 명령줄 옵션 해석

makersweb 2020.09.01 22:52 조회 수 : 2232

C/C++로 작성된 응용프로그램의 main함수는 두개의 인수(관습적으로 argc와 argv)를 전달받을 수 있다. 프로그래머는 응용프로그램에 명령줄옵셔들을 전달하여 프로그램을 상황에 따라 제어하는데 많이 사용된다. (사실 main함수에는 세번째 인수로 환경변수를 전달 받을 수 있다.)

 
Qt응용프로그램도 C++ 응용프로그램이므로 main함수에 옵션을 전달 할 수 있다. 이 글에서는 Qt응용프로그램에서 옵션을 해석할 때 편리하게 사용할 수 있는 클래스를 소개하고 간단하게 사용하는 방법을 설명한다.
 
명령줄 옵션은 보통 짧은 이름 옵션과 긴 이름 옵션으로 분류하는데 짧은 이름 옵션은 -(하이픈)과 영문자, 숫자 또는 기호의 단일 문자로 나타내는 옵션 형식이고 긴 이름 옵션은 --(하이픈 두개)에 영단어로 표현하는 형식이다. 
 
 
QCoreApplication 객체에 인수 전달
 
Qt 기반의 응용프로그램의 main함수는 대부분 QCoreApplication 객체를 생성하고 이때 main함수의 인수를 전달한다. 다음은 기본적인 Qt 응용프로그램 main함수를 보여준다.
#include <QApplication>
#include "mainwindow.h"

int main(int argc, char *argv[])
{
    // QApplication 객체를 생성할 때 argc와 argv를 전달한다.
    QApplication app(argc, argv);

    // MainWindow를 생성한다.
    MainWindow w;
    w.resize(1280, 720);
    w.show();

    return app.exec();
}

 

이 후 QApplication 객체를 통해 인수를 얻을 수 있다. 

QStringList args = app.arguments();

 

 

QCommandLineParser 클래스로 옵션 해석
 
QCommandLineParser 클래스는 편리하게 명령 줄 옵션을 처리하는 방법을 제공한다. 옵션 집합을 정의하고, 명령 줄 인수를 구문 분석하고, 실제로 사용 된 옵션과 옵션 값을 저장하는 기능을 제공한다.
 
이 클래스를 사용하려면 다음과 같이 헤더파일을 포함해줘야 한다.
#include <QCommandLineParser>
 
다음은 QCommandLineParser 클래스를 사용하는 기본적인 예제 소스 코드이다.
int main(int argc, char *argv[])
{
    // QApplication 객체를 생성할 때 argc와 argv를 전달한다.
    QApplication app(argc, argv);

    MainWindow w;
    w.resize(1280, 720);

    QCommandLineParser parser;

    // -h (help)옵션을 추가해준다.
    parser.addHelpOption();

    // 짧은 이름(-s)을 가진 bool 옵션 추가.
    QCommandLineOption showWindowOption("s", QCoreApplication::translate("main", "Show Window"));
    parser.addOption(showWindowOption);

    // 여러 이름을(-f, --force)가진 bool 옵션 추가.
    QCommandLineOption forceOption(QStringList() << "f" << "force",
            QCoreApplication::translate("main", "Overwrite existing files."));
    parser.addOption(forceOption);

    // 실제 명령 줄 인수 처리
    parser.process(app);

    bool show = parser.isSet(showWindowOption);

    if(show){
        /* 옵션(-s)이 포함되면 윈도우를 보여준다. */
        w.show();
    }

    return app.exec();
}

 

번호 제목 글쓴이 날짜 조회 수
공지 Qt프로그래밍(QtQuick) Beginner를 위한 글 읽는 순서 운영자 2019.01.05 85935
19 QThread 소개 및 예제 makersweb 2019.12.25 19485
18 Qt애플리케이션 객체(QCoreApplication, QGuiApplication, QApplication) 에 대해서 makersweb 2019.11.11 10110
17 QLabel의 텍스트 색과 배경색을 변경 makersweb 2020.02.25 6622
16 QPushButton 의 커스텀 이미지버튼 file makersweb 2019.11.05 6394
15 QQuickImageProvider 를 이용한 Qml 에서 이미지 표시 makersweb 2015.10.18 5999
14 컨테이너 클래스 - QVector makersweb 2020.03.17 2842
» main함수 명령줄 옵션 해석 makersweb 2020.09.01 2232
12 Qt로 데이터를 직렬화(serialization)하는 방법 makersweb 2020.08.04 2059
11 QRandomGenerator 클래스를 사용하여 난수(random values) 생성 makersweb 2020.10.17 1570
10 QThread 및 QMutex 예제 makersweb 2021.01.12 1351
9 재진입(Reentrancy) 및 스레드 안전성(Thread-Safety) makersweb 2020.04.19 1216
8 Qt 스마트 포인터 (QSharedPointer, QScopedPointer, QPointer) makersweb 2022.08.18 1139
7 QScopedPointer 소개 및 사용법 makersweb 2019.11.29 1027
6 QProcess 예제 (프로그램 재시작) file makersweb 2023.01.25 899
5 응용프로그램 자동실행 설정 (on Windows) makersweb 2021.05.08 564
4 QML의 사용자 정의 Image makersweb 2023.09.17 559
3 하드디스크 드라이브 여유 공간 계산 file makersweb 2023.01.15 511
2 Base64로 인코딩된 파일을 복원 makersweb 2023.08.06 450
1 HTTPS URL을 연결할 때 SslHandshakeFailedError 오류 makersweb 2022.07.31 358