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

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Bibliothèque standard C Discussion :

Fork et entree/sorties standards : bonne pratique ?


Sujet :

Bibliothèque standard C

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Modérateur
    Avatar de gangsoleil
    Homme Profil pro
    Manager / Cyber Sécurité
    Inscrit en
    Mai 2004
    Messages
    10 150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Manager / Cyber Sécurité

    Informations forums :
    Inscription : Mai 2004
    Messages : 10 150
    Par défaut Fork et entree/sorties standards : bonne pratique ?
    Bonjour,

    Dans un programme, je dois exécuter un code externe. Pour cela, je vais probablement dupliquer le processus, et appeler le exec dans le fils, afin que le père puisse continuer son travail (je ne suis pas intéressé par le fait que le code externe plante ou non, ni par le code de retour).

    Seulement voila, je me demande quelle est la bonne pratique concernant les entrée/sorties standards (stdin, stdout, stderr) : j'ai pu voir des cas ou ils sont fermés (close (STDOUT_FILENO); par exemple), d'autres cas ou ils sont rouverts sur /dev/null (je travaille sous Unix, mais peu importe), et d'autres cas où rien n'est fait.

    Quelle est la bonne solution, s'il y en a une ? Et si en plus vous pouviez m'indiquer pourquoi, ce serait encore mieux.

    Merci par avance.
    "La route est longue, mais le chemin est libre" -- https://framasoft.org/
    Les règles du forum

  2. #2
    Rédacteur

    Avatar de ram-0000
    Homme Profil pro
    Consultant en sécurité
    Inscrit en
    Mai 2007
    Messages
    11 517
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 62
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : Consultant en sécurité
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2007
    Messages : 11 517
    Par défaut
    Salut ,

    Je n'ai pas LA solution mais juste quelques idées et remarques.

    Ne pas les fermer ? Cela risque de perturber les affichages et les saisies au cas où le père et le fils se mettent à écrire ou à attendre des saisies au clavier.

    Les réouvrir sur /dev/null ? Je ne vois pas trop l'intérêt.

    Les fermer ? Je l'ai vu souvent faire sur des démons et cela ne gêne pas plus que cela.

    Donc, mon choix les fermer.
    Raymond
    Vous souhaitez participer à la rubrique Réseaux ? Contactez-moi

    Cafuro Cafuro est un outil SNMP dont le but est d'aider les administrateurs système et réseau à configurer leurs équipements SNMP réseau.
    e-verbe Un logiciel de conjugaison des verbes de la langue française.

    Ma page personnelle sur DVP
    .

  3. #3
    Expert confirmé

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 610
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 610
    Billets dans le blog
    2
    Par défaut
    moi je re-dirigerais simplement les entrées sorties vers 2 fichiers tempo, éventuellement vides...

    Ce qui permettrait, au cas où tu veuilles le faire un jour, de récupérer les sorties sans les mélanger, et aussi où tu veuilles créer au vol un fichier d'entrées..

    Sans les fermer, en utilisant simplement les >, <, ou bien des paramètres du style -in ... -out ....

    Soit en laissant faire la gestion (< ou >) des stdin, stdout, soit en testant dans les progs :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    FILE *Entree ;
     
    if ( strncmp ( argv[i], "-in" ) == 0 )
     {
          Entree = fopen ( argv[i+1], "r" );
     }
    else
         Entree = stdin ;
     
    ...
     
    if ( Entree != stdin )
       fclose ( Entree );
    par exemple


    et sinon


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    exec ( "myprog < monentree > masortie 2>&1");
    où les blocs " < monentree" ou "> masortie" peuvent ne pas apparaître...

  4. #4
    Modérateur
    Avatar de gangsoleil
    Homme Profil pro
    Manager / Cyber Sécurité
    Inscrit en
    Mai 2004
    Messages
    10 150
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Manager / Cyber Sécurité

    Informations forums :
    Inscription : Mai 2004
    Messages : 10 150
    Par défaut
    Hello,

    Citation Envoyé par souviron34 Voir le message
    moi je re-dirigerais simplement les entrées sorties vers 2 fichiers tempo, éventuellement vides...

    Ce qui permettrait, au cas où tu veuilles le faire un jour, de récupérer les sorties sans les mélanger, et aussi où tu veuilles créer au vol un fichier d'entrées..

    Sans les fermer, en utilisant simplement les >, <, ou bien des paramètres du style -in ... -out ....

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    exec ( "myprog < monentree > masortie 2>&1");
    où les blocs " < monentree" ou "> masortie" peuvent ne pas apparaître...
    En fait, les entrées/sorties du programme appelé sont déjà gérées (avec > pour 1 et pour 2). Ce qui m'intéressait, ce sont vraiment les descripteurs de fichiers du fils. Je pense que dans un premier temps, je vais les fermer, et je verrai plus tard si mon besoin change.

    Merci a vous pour vos conseils.
    "La route est longue, mais le chemin est libre" -- https://framasoft.org/
    Les règles du forum

  5. #5
    Membre averti
    Inscrit en
    Décembre 2006
    Messages
    37
    Détails du profil
    Informations forums :
    Inscription : Décembre 2006
    Messages : 37
    Par défaut
    Ne pas les fermer peut entrainer des affichages intermittents dans la fenêtre xterm depuis lequel le prog père est lancé.

  6. #6
    Expert confirmé

    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    10 610
    Détails du profil
    Informations personnelles :
    Âge : 68
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 10 610
    Billets dans le blog
    2
    Par défaut
    Citation Envoyé par themus Voir le message
    Ne pas les fermer peut entrainer des affichages intermittents dans la fenêtre xterm depuis lequel le prog père est lancé.
    et cela peut-être intéressant par exemple pour loguer un dialogue ou une succession de demandes

Discussions similaires

  1. entree sortie standard
    Par morphemia dans le forum Langage
    Réponses: 9
    Dernier message: 24/03/2011, 15h49
  2. [Critique] Bonnes pratiques des standards du Web
    Par Bovino dans le forum Général Conception Web
    Réponses: 3
    Dernier message: 26/01/2011, 22h48
  3. entree et sortie standard
    Par eldiablol dans le forum C
    Réponses: 8
    Dernier message: 06/11/2006, 17h12

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo