|
Publicité ' | ||||||||||||||||||||||
|
|
#1 |
|
Candidat au titre de Membre du Club
![]() Inscription : avril 2008 Messages : 101 ![]() |
bonjour
j'ai crée un programme en c++ et je veux lance le .exe en arrière plan comme un precess pour ne pas déranger les utilisateur. est ce qu'il y a une méthode pour faire ça? merci |
|
|
00
|
|
|
#2 |
|
Expert Confirmé Sénior
![]() Paul BacelarDéveloppeur informatique Inscription : février 2005 Messages : 2 651 ![]() |
S'il n'a pas besoin d'un utilisateur connecté, faites en un service Windows, si c'est sous Windows bien sûr.
http://en.wikipedia.org/wiki/Windows_service |
|
|
00
|
|
|
#3 |
|
Candidat au titre de Membre du Club
![]() Inscription : avril 2008 Messages : 101 ![]() |
mon script s’exécute après l'ouverture du session d'un utilisateur
|
|
|
00
|
|
|
#4 |
|
Expert Confirmé Sénior
![]() Paul BacelarDéveloppeur informatique Inscription : février 2005 Messages : 2 651 ![]() |
Je ne vois pas trop le problème.
Tout programme non console qui n'ouvre pas de fenêtre est dans ce cas de figure. |
|
|
00
|
|
|
#5 | ||
|
Candidat au titre de Membre du Club
![]() Inscription : avril 2008 Messages : 101 ![]() |
je vais éclairer le chose
j'ai crée un programme en c/c++ sous windows qui s’exécute au lancement d'une session windows ce programme se connecte sur une base de données MYSQL pour insérer (login utilisateur,nom du machine,ip adresse,date_heure se connexion) et sur mon programme j'ai rajouté une fonction qui s’exécute chaque 5 sec pendant 30 min si le poste agent n'arrive pas a se connecter à la base de données pour insérer les données et mon problème ce que le fenêtre dos reste afficher devant les yeux de l'utilisateur chose qui empêche son travail et aussi il peut la fermer avant de terminer le programme ma demande est ce je peux lancer mon programme en arrière-plan comme ?si oui c'est quoi la méthode voila mon code c/c++ Code :
|
||
|
|
00
|
|
|
#6 | ||
|
Expert Confirmé Sénior
![]() Paul BacelarDéveloppeur informatique Inscription : février 2005 Messages : 2 651 ![]() |
Vous cherchez midi à 14 heures.
Citation:
Ce n'est pas une fenêtre DOS mais une console, donc Citation:
Assez logique avec une signature C d'il y a 40 ans : Créez un projet Win32 NON CONSOLE, le nom du point d'entré sera très vraisemblablement WinMain et non main. P.S.: moi, j'aurais penché vers l'utilisation des fonctionnalités intégrées d'Active Directory plutôt que ce bricolage. http://technet.microsoft.com/en-us/l.../bb742436.aspx |
||
|
|
00
|
|
|
#7 |
|
Membre éprouvé
![]() Développeur informatique Inscription : janvier 2010 Messages : 339 ![]() |
Une console à plus de 17 ans si ont rentre dans se type de petit délire
Actuellement c'est une invite de commande ou l'emulation d'un terminal DOS Il y a une méthode crade qui s'appel le Ghost. En gros tu fais un programme qui va forker ton programme que l'ont va appeler papa. En gros papa se termine salement sans fermer le fils et donc tu te retrouve avec un ghost soit un processus qui tourne sans réel attache en gros. |
|
|
11
|
|
|
#8 | ||
|
Expert Confirmé Sénior
![]() Paul BacelarDéveloppeur informatique Inscription : février 2005 Messages : 2 651 ![]() |
jouana, ton second prénom c'est Hibernatus ???
![]() Citation:
Et le prompt affiché par cmd.exe n'est pas une console TTY. jouana, tu mélanges tout et n'importe quoi. Citation:
Ce truc, c'est de l'Unix des années 60, et c'est pas parce que Windows était vaguement compatible POSIX 1 pour l'US Army, dans les années 80/90, qu'il faut l'utiliser. P.S.: ce n'est pas un ghost, n'y même un zombi Unix, et il faut faire un détachement explicite de la console hérité par le programme parent. C'est dans les 3 premiers descripteurs de fichiers, si je me souviens bien de mes cours de paléontologie informatique. |
||
|
|
01
|
|
|
#9 |
|
Membre éprouvé
![]() Développeur informatique Inscription : janvier 2010 Messages : 339 ![]() |
Mouais les zombies sont encore utilisé sous linux et BSD.
Enfin bon après pas la peine d'être désagréable j'offre une solution comme une autres. Ensuite penches toi sur la création de service windows, zaki_1982 tu devrais trouver ton bonheur. Et un terminal n'est pas propre à UNIX, c'est juste une interaction entrée sortie, que tu retrouve sur beaucoup d'OS différents, TTY en est un parmi beaucoup d'autres. Mais je te rejoins sur le fait que DOS n'est plus depuis windows NT et que l'ont a maintenant des émulations de ce derniers. |
|
|
00
|
|
|
#10 | |
|
Expert Confirmé Sénior
![]() Paul BacelarDéveloppeur informatique Inscription : février 2005 Messages : 2 651 ![]() |
Citation:
Il n'y a RIEN de DOS dans Windows. RIEN RIEN RIEN même plus l'intéruption 21, RIEN. |
|
|
|
01
|
|
|
#11 | |
|
Membre éprouvé
![]() Développeur informatique Inscription : janvier 2010 Messages : 339 ![]() |
Sans rentrer dans un grand débat la dessus un petit extrait de Wikipedia
Citation:
Soit quelque chose qui imite le fonctionnement de DOS. |
|
|
|
00
|
|
|
#12 | |
|
Expert Confirmé Sénior
![]() Paul BacelarDéveloppeur informatique Inscription : février 2005 Messages : 2 651 ![]() |
L'URL, s'il te plait, que j'aille corriger de ce pas.
MS-DOS, c'est pas qu'un interpréter de commande qui fait clignoter un curseur avec les commandes du BIOS. Faut arrêter de déconner à un moment. ![]() Et il va contenir Linux quand je vais installer cigwin sur ma machine ? Non, mais ce que après, les commandes "Linux", elle vont être comprise de l'interpréter de commande de Windows (Le PATH fait de petit miracle émulatique ).Non, mais, ce qui faut pas entendre. Citation:
Enfin, tout ça pour faire un programme qui ne sert à rien puisque toutes ces informations sont déjà dans l'Active Directory du domaine Windows.
|
|
|
|
00
|
|
|
#13 |
|
Nouveau Membre du Club
![]() Alexandre Technicien réseau Inscription : décembre 2012 Messages : 39 ![]() |
Je me rappelle que pour avoir créé simplement un programme non-fenêtré, j'avais compilé mon code en précisant que c'était un processus, dans l'IDE Dev-C++, et comparé à un Code::blocks ou je ne sais quoi, comme par magie ça avait fonctionné.
Désolé je ne me rappelle plus exactement comment j'avais réalisé ceci, mais ça doit pouvoir se retrouver facilement, et comme j'ai plus DevC++ d'installé sur mon PC ... En tout cas tout ca pour dire que tu dois pas te compliquer la vie, normalement ca doit se faire comme ca. Cdt, Vespiras |
|
00
|
|
|
#14 |
|
Expert Confirmé Sénior
![]() Paul BacelarDéveloppeur informatique Inscription : février 2005 Messages : 2 651 ![]() |
"un processus" ou un service ?
Et oui, ce n'est pas compliqué, si on sait ce qu'on fait. |
|
|
00
|
|
|
#15 | |
|
Membre Expert
![]() ![]() david Responsable développement Inscription : décembre 2003 Messages : 1 295 ![]() |
Bonjour.
Citation:
Pour le service, il suffit de faire une boucle et d'attendre que l'utilisateur soit loggé. Pour l'application Win32, utiliser un timer. PS : si le but de votre programme, c'est de scruter les logging des utilisateurs, vous avez ces informations dans le journal d'évènements Windows... Suffit de récupérer ces journaux.
__________________
Media Foundation video decoder mpeg1/mpeg2, MediaSource Kinect http://sourceforge.net/projects/mfnode/ http://jeux.developpez.com/faq/directx/?page=dshow |
|
|
|
00
|
|
|
#16 | |
|
Expert Confirmé Sénior
![]() Paul BacelarDéveloppeur informatique Inscription : février 2005 Messages : 2 651 ![]() |
Citation:
Moi, fainéant, et fière de l'être. ![]()
|
|
|
|
00
|
|
|
#17 |
|
Membre Expert
![]() ![]() david Responsable développement Inscription : décembre 2003 Messages : 1 295 ![]() |
Bonjour Bacelar.
Je veux bien croire qu'il y a de meilleures approches. Mais de là à dire que c'est très moyen, un malheureux petit timer de 5 secondes ![]() PS : je le prends au second degré...
__________________
Media Foundation video decoder mpeg1/mpeg2, MediaSource Kinect http://sourceforge.net/projects/mfnode/ http://jeux.developpez.com/faq/directx/?page=dshow |
|
|
00
|
|
|
#18 |
|
Expert Confirmé Sénior
![]() Paul BacelarDéveloppeur informatique Inscription : février 2005 Messages : 2 651 ![]() |
Alors l'approche timer :
- non partage du scheduling système : gaspillage de ressource système - plantage sur problème transitoire (connexion réseau ...) : pas de logs automatique, pas de redémarrage automatique (celui qui me colle un try catch(...){}, je le baffe) - Intégration dans une console de monitoring, monsieur le développeur, il va se la cogner à la main - les timers, c'est la vraie jungle et les plus fiable, c'est du multi-threading obligatoire, est-ce justifié pour un pauvre programme basique ? - paramétrage via un console standard que même Mme Michu peut maitriser, donc, a fortiori aussi un admin système, même pas très dégourdi. - paramétrage au niveau des scripts d'installations totalement customisable avec des primitives que notre cher admin système connait sur le bout des doigts. ... Avec un scheduled task, j'ai aucun de ces inconvénients et tout ces avantages GRATIS (0+0=0 ligne de code en plus Non, franchement, je ne vois aucun avantages aux timers "embarqués" pour une application de ce type, mais alors au niveau emmerdes, c'est pas mal. ![]() ![]() Mais je vois le mal partout (normal, je suis développeur et Murphy est mon ami moldavi, je suis tout ouïe pour entendre votre plaidoyer pour le timer embarqué dans l'application.
|
|
|
00
|
Copyright © 2000-2013 - www.developpez.com