IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)


API Windows en C

Une seule instance pour l'application.

Par CGi

Le 21 juillet 2006




Introduction :

Nous allons voir comment n'ouvrir qu'une seule instance pour une application Win32. Nous utiliserons pour cela les Mutex.


Description :

Pour arriver à nos fins nous créons un Mutex avec un nom unique transmis dans le troisième paramètre de la fonction CreateMutex. Créer un autre Mutex dans le système avec ce nom provoquera une erreur (ERROR_ALREADY_EXISTS). En lancant une deuxième fois l'application, elle va tenter de créer à nouveau le mutex, ce qui provequera l'erreur que l'on traitera afin de fermer la deuxième instance que l'on a tenté d'ouvrir.

        HANDLE hMutex;
        hMutex = CreateMutex (NULL,FALSE,"Nom Unique du Mutex");
        if (GetLastError() == ERROR_ALREADY_EXISTS) return 0;  


Nous ferons donc ce test au tout debut du WinMain avant la création de la fenètre.


Code complet :

winmain.c :

#include <windows.h>

LONG APIENTRY WndProc(HWND hwnd, UINT uMsg, UINT wParam, LONG lParam);

HINSTANCE hInst;

int WINAPI WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance,
                                                  LPSTR lpCmdLine, int nCmdShow)
{
        HWND hwndMain ;
        MSG msg;
        WNDCLASS wc;

        HANDLE hMutex;
        hMutex = CreateMutex (NULL,FALSE,"Nom Unique du Mutex");
        if (GetLastError() == ERROR_ALREADY_EXISTS) return 0;

        hInst = hInstance;

        wc.style = 0;
        wc.lpfnWndProc = (WNDPROC) WndProc;
        wc.cbClsExtra = 0;
        wc.cbWndExtra = 0;
        wc.hInstance = hInstance;
        wc.hIcon = LoadIcon((HINSTANCE) NULL, IDI_APPLICATION);
        wc.hCursor = LoadCursor((HINSTANCE) NULL, IDC_ARROW);
        wc.hbrBackground = (HBRUSH)(1 + COLOR_BTNFACE);
        wc.lpszMenuName =  MAKEINTRESOURCE(1); ;
        wc.lpszClassName = "MainWndClass";
        if (!RegisterClass(&wc))  return FALSE;


        hwndMain = CreateWindow("MainWndClass", "WinApi",
                 WS_OVERLAPPEDWINDOW, CW_USEDEFAULT, CW_USEDEFAULT,
                            360, 280,  NULL,  NULL, hInstance,  NULL);
        ShowWindow(hwndMain, nCmdShow);
        UpdateWindow(hwndMain);

       while (GetMessage(&msg, NULL, 0, 0))
       {
          TranslateMessage(&msg);
          DispatchMessage(&msg);
       }
       return 0;
}

LONG APIENTRY WndProc(HWND hwnd, UINT uMsg, UINT wParam, LONG lParam)
{
 switch ( uMsg ) {

 case WM_DESTROY:
       PostQuitMessage(0);
       return 0;
  }
 return DefWindowProc(hwnd, uMsg, wParam, lParam);
}

J'ai testé les compilations avec C++ Builder et DevC++.


A vos PC.

CGi



Sommaire



C/C++
  Les pointeurs du C/C++.   Les listes chaînées.             Liste simple.             Liste triée.             Liste double.   Les arbres.   Les tas.   Le C orienté objets ?

  1 - La fenêtre principale.   2 - Contrôles et messages.   3 - Les commandes.   4 - Dialogue std.   5 - Contexte de périph.   6 - Dessiner.   7 - Les ressources.   8 - Dialogue perso.   9 - Dialogue comm.   10 - Les accélérateurs.

Assembleur
  Assembleur sous Visual C++.

C++ BUILDER
  Trucs et astuces.   Composant.   TRichEdit.   TDrawGrid.   Application MDI.   TThread.   wxWidgets.   Style Win XP.

  Première application.   Construire un menu.   Dessiner.   Sisers, Timers...   Dialogues standards.   Dialogues perso.

DotNet
  Composant C# Builder.   Contrôle WinForm.   Application MDI.

Java
  Applet java.





Copyright 2002-2020 CGi - Tous droits réservés CGi. Toutes reproduction, utilisation ou diffusion de ce document par quelque moyen que ce soit autre que pour un usage personnel doit faire l'objet d'une autorisation écrite de la part de l'auteur, propriétaire des droits intellectuels.
Les codes sources de ce document sont fournis en l'état. L'utilisateur les utilise à ses risques et périls, sans garantie d'aucune sorte de la part de l'auteur. L'auteur n'est responsable d'aucun dommage subi par l'utilisateur pouvant résulter de l'utilisation ou de la distribution des codes sources de ce document.
De la même façon, l'auteur n'est en aucun cas responsable d'une quelconque perte de revenus ou de profits, ou de données, ou de tous dommages directs ou indirects, susceptibles de survenir du fait de l'utilisation des codes sources de ce document, quand bien même l'auteur aurait été averti de la possibilité de tels dommages. L'utilisation des codes sources de ce document vaut acceptation par l'utilisateur des termes de la licence ci-dessus.