NOM
strcpy, strncpy - Copier une chaîne.
SYNOPSIS
#include <string.h>
char *strcpy(char *dest, const char *src);
char *strncpy(char *dest, const char *src, size_t n);
La fonction strcpy() copie la chaîne pointée par src, y compris le
caractère nul (« \0 ») final dans la chaîne pointée par dest. Les deux
chaînes ne doivent pas se chevaucher. La chaîne dest doit être assez
grande pour accueillir la copie.
La fonction strncpy() est identique, sauf qu’au plus n octets de src
sont copiés. Attention : s’il n’y a pas de caractère nul dans les n
premiers octets de src, la chaîne résultante dans dest ne disposera pas
de caractère nul final.
Si la longueur de src est inférieure à n, strncpy() remplit la fin de
dest avec des caractères nuls.
Une implémentation simple de strncpy() pourrait être :
char*
strncpy(char *dest, const char *src, size_t n){
size_t i;
for (i = 0 ; i < n && src[i] != '\0' ; i++)
dest[i] = src[i];
for ( ; i < n ; i++)
dest[i] = '\0';
return dest;
}
VALEUR RENVOYÉE
Les fonctions strcpy() et strncpy() renvoient un pointeur sur la chaîne
destination dest.
CONFORMITÉ
SVr4, BSD 4.3, C89, C99.
NOTES
Certains programmeurs considèrent strncpy() comme inefficace et propice
aux erreurs. Si le programmeur sait (c’est-à-dire en ajoutant du code
pour effectuer le test !) que la taille de dest est supérieure à la
longueur de src, alors strcpy() peut être utilisée.
S’il n’y a pas d’octet nul de fin dans les n premiers caractères de
src, strncpy() produit une chaîne non terminée dans dest. Les
programmeurs évitent souvent cette erreur en forçant la fin de chaîne
de cette façon :
strncpy(buf, str, n);
if (n > 0)
buf[n - 1]= '\0';
BOGUES
Si la chaîne de destination d’un strcpy() n’est pas suffisamment
grande, n’importe quoi peut survenir. Un dépassement de tampon pour une
chaîne de taille fixe est la technique favorite de pirates pour prendre
le contrôle d’une machine. À chaque fois qu’un programme lit ou copie
des données dans un tampon, le programme doit d’abord vérifier qu’il y
a suffisamment de place. Ça peut ne pas être nécessaire si vous pouvez
montrer qu’un dépassement est impossible, mais faites attention : les
programmes changes au cours du temps, et ce qui était impossible peut
devenir possible.
VOIR AUSSI
bcopy(3), memccpy(3), memcpy(3), memmove(3), strpcpy(3), wcscpy(3),
wcsncpy(3)
COLOPHON
Cette page fait partie de la publication 3.23 du projet man-pages
Linux. Une description du projet et des instructions pour signaler des
anomalies peuvent être trouvées à l’adresse
http://www.kernel.org/doc/man-pages/.
TRADUCTION
Cette page de manuel a été traduite et mise à jour par Christophe
Blaess <http://www.blaess.fr/christophe/> entre 1996 et 2003, puis par
Alain Portal <aportal AT univ-montp2 DOT fr> jusqu’en 2006, et mise à
disposition sur http://manpagesfr.free.fr/.
Les mises à jour et corrections de la version présente dans Debian sont
directement gérées par Nicolas François
<nicolas.francois@centraliens.net> et l’équipe francophone de
traduction de Debian.
Veuillez signaler toute erreur de traduction en écrivant à
<debian-l10n-french@lists.debian.org> ou par un rapport de bogue sur le
paquet manpages-fr.
Vous pouvez toujours avoir accès à la version anglaise de ce document
en utilisant la commande « man -L C <section> <page_de_man> ».