단일 인스턴스만 허용하는 응용프로그램을 구현하고자 할 때 KDSingleApplication 클래스가 도움이된다.
단일 인스턴스 정책이란?
단일 인스턴스 정책은 특정 사용자 세션에 대해 유일한 인스턴스를 생성하려는 애플리케이션을 의미한다. 응용프로그램을 여러 번 시작하더라도 이러한 응용프로그램은 여러 개별 인스턴스를 생성하지 않는다. 대신 기존 인스턴스에 알림이 전송되고 해당 인스턴스에서 일부 작업을 수행한다. 예를 들어 일반적으로 창이 표시되고 (숨겨진 경우) 전경으로 올라간다.
이 메커니즘은 응용프로그램과 관련된 파일을 열 때 파일관리자에서와 같이 응용 프로그램이 간접적으로 시작되는 경우에도 작동한다. 이 경우 새 인스턴스 (파일 관리자에 의해 시작됨)는 단순히 기존 인스턴스에 선택한 파일을 열도록 지시한 다음 새 인스턴스가 즉시 종료한다.
문제는 대부분의 운영체제에서 일반적으로 애플리케이션을 시작할 때마다 새 인스턴스를 생성한다.따라서 단일 인스턴스 정책을 준수하려면 몇 가지 논리가 필요하다. KDSingleApplication
은 이러한 논리를 구현한다.
구체적으로 어떻게 구현하는가?
KDSingleApplication
은 몇 가지 저장소에 있는 기타 유사한 코드의 재 설계이다.
KDSingleApplication
의 가장 큰 장점은 QCoreApplication
, QGuiApplication
, QApplication
을 상속하여 대체하지 않는다는 것이다. 이러한 상속은 일반적으로 잘못된 설계의 결과다. 솔루션의 자체 코드를 수정하지 않으면 사용중인 애플리케이션 클래스를 제어할 수 없다. 또한 솔루션과 응용프로그램 클래스의 다른 사용자 지정 하위 클래스를 사용할 수 없다. 이는 응용프로그램 객체가 하나만있을 수 있기 때문에 일부 시나리오에서 유용하다.
KDSingleApplication
은 대신 응용프로그램 객체를 보완한다. 필요한 종류의 Qt응용프로그램 객체를 만든 다음 KDSingleApplication
객체를 만들기만 하면 된다.
int main(int argc, char **argv)
{
QApplication app(argc, argv);
KDSingleApplication kdsa;
...
그 다음 인스턴스가 "primary" 인스턴스인지 "secondary"인스턴스인지 확인해야한다. primary 인스턴스는 secondary 인스턴스에서 임의의 메시지를 수신하고 응용 프로그램 방식 (파일 열기, 응용 프로그램의 기본 창 표시 및 올리기 등)으로 작업 할 수 있다. 예를 들면 다음과 같다.
if (kdsa.isPrimaryInstance()) {
/* primary: listen to messages */
QObject::connect(&kdsa, &KDSingleApplication::messageReceived,
/* handle messages from the secondary instances */);
} else {
/* secondary: send message to the primary */
kdsa.sendMessage("some message to the primary");
/* quit */
return 0;
}
KDSingleApplication과 함께 제공되는 예제는 사용방법을 더 자세히 보여준다. GitHub 저장소에서 다운로드 할 수 있다. (MIT 라이선스에 따라 배포된다.)
https://github.com/KDAB/KDSingleApplication