|
|||||||
|
|
DUPSection: Manuel du programmeur Linux (2)Updated: 18 juillet 2003 Index Return to Main Contents NOMdup, dup2 - Dupliquer un descripteur de fichier.SYNOPSIS#include <unistd.h> int dup(int oldfd); int dup2(int oldfd, int newfd); DESCRIPTIONdup et dup2 créent une copie du descripteur de fichier oldfd.Après un appel réussi à dup ou dup2, l'ancien et le nouveau descripteurs peuvent être utilisés de manière interchangeable. Ils partagent les verrous, les pointeurs de position et les drapeaux. Par exemple si le pointeur de position est modifié en utilisant lseek sur l'un des descripteurs, la position est également changée pour l'autre. Les deux descripteurs ne partagent toutefois pas le drapeau Close-on-exec. dup utilise le plus petit numéro inutilisé pour le nouveau descripteur. dup2 transforme newfd en une copie de oldfd, fermant auparavant newfd si besoin est. VALEUR RENVOYÉEdup et dup2 renvoient le nouveau descripteur, ou -1 s'ils échouent, auquel cas errno contient le code d'erreur.ERREURS
ATTENTIONLes erreurs renvoyées par dup2 sont différentes de celles retournées par fcntl(...,F_DUPFD,...) si newfd n'est pas dans les valeurs autorisées. Sur certains systèmes dup2 retourne aussi parfois EINVAL comme F_DUPFD.BOGUESSi newfd était ouvert, toutes les erreurs susceptibles d'être rapportées par close() sont perdues. Un programmeur soigneux n'utilisera pas dup2 sans fermer newfd d'abord.CONFORMITÉSVr4, SVID POSIX, X/OPEN, BSD 4.3. SVr4 documente des conditions d'erreur supplémentaires EINTR et ENOLINK. POSIX.1 ajoute également EINTR.VOIR AUSSIfcntl(2), open(2), close(2)TRADUCTIONChristophe Blaess, 1996-2003.
Index | ||||||
|
|
|
Home :: Copyright :: Privacy :: Credits :: Get a free Linuxinfor Email Account Document on this page is part of "Linuxinfor Man Pages in HTML Format: man2". See Index Page for more info about Authorship and Copyright. 1999-2009 Linuxinfor.com. No rights reserved. |