sourCEntral - mobile manpages

pdf

cfree

NOM

cfree - Libérer la mémoire allouée

BIBLIOTHÈQUE

Bibliothèque C standard (libc, -lc)

SYNOPSIS

#include <stdlib.h>

/* Avec SunOS 4 */
int cfree(void *
ptr);

/* Avec la glibc ou avec FreeBSD libcompat */
void cfree(void *
ptr);

/* Avec SCO OpenServer */
void cfree(char
ptr[.size * .num], unsigned int num, unsigned int size);

/* Dans Solaris watchmalloc.so.1 */
void cfree(void
ptr[.elsize * .nelem], size_t nelem, size_t elsize);

Exigences de macros de test de fonctionnalités pour la glibc (consulter feature_test_macros(7)) :

cfree() :
Depuis la glibc 2.19 :
_DEFAULT_SOURCE
Pour la glibc 2.19 et précédentes :
_BSD_SOURCE || _SVID_SOURCE

DESCRIPTION

Cette fonction ne devrait jamais être utilisée. Utilisez free(3) à la place. À partir de la glibc 2.26, elle a été supprimée de la glibc.

cfree avec un argument
Dans la glibc, la fonction cfree() est un synonyme de free(3), « ajoutée pour être compatible avec SunOS ».

D’autres systèmes ont d’autres fonctions du même nom. La déclaration se trouve parfois dans <stdlib.h> et parfois dans <malloc.h>.

cfree avec trois arguments
Certaines versions de SCO et de Solaris ont des bibliothèques malloc avec une fonction cfree() à 3 arguments, apparemment par analogie à calloc(3).

Si vous en avez besoin et que vous faites un portage, ajoutez

#define cfree(p, n, s) free((p))

dans votre fichier.

Une question fréquemment posée est : « Puis-je utiliser free(3) pour libérer de la mémoire allouée avec calloc(3), ou bien dois-je utiliser cfree() ? ». La réponse est : utilisez free(3).

Un manuel de SCO dit : « La routine cfree est fournie pour être conforme à la norme iBCSe2 et faciliter les appels de free. Les arguments num et size de cfree ne sont pas utilisés. »

VALEUR RENVOYÉE

La version SunOS de cfree() (qui est un synonyme de free(3)) renvoie 1 si elle réussit et 0 si elle échoue. En cas d’erreur, errno est positionnée à EINVAL : la valeur de ptr n’était pas un pointeur vers un bloc précédemment alloué par l’une des routines de la famille malloc(3).

VERSIONS

La fonction cfree() a été supprimée dans la glibc 2.26.

ATTRIBUTS

Pour une explication des termes utilisés dans cette section, consulter attributes(7).

img

STANDARDS

La version à trois arguments de cfree() est utilisée par SCO pour être conforme à la norme iBCSe2 : « Intel386 Binary Compatibility Specification, Edition 2 ».

VOIR AUSSI

malloc(3)

TRADUCTION

La traduction française de cette page de manuel a été créée par Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan DOT rafin AT laposte DOT net>, Thierry Vignaud <tvignaud AT mandriva DOT com>, François Micaux, Alain Portal <aportal AT univ-montp2 DOT fr>, Jean-Philippe Guérard <fevrier AT tigreraye DOT org>, Jean-Luc Coulon (f5ibh) <jean-luc DOT coulon AT wanadoo DOT fr>, Julien Cristau <jcristau AT debian DOT org>, Thomas Huriaux <thomas DOT huriaux AT gmail DOT com>, Nicolas François <nicolas DOT francois AT centraliens DOT net>, Florentin Duneau <fduneau AT gmail DOT com>, Simon Paillard <simon DOT paillard AT resel DOT enst-bretagne DOT fr>, Denis Barbier <barbier AT debian DOT org>, David Prévot <david AT tilapin DOT org> et Jean-Pierre Giraud <jean-pierregiraud AT neuf DOT fr>

Cette traduction est une documentation libre ; veuillez vous reporter à la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n’y a aucune RESPONSABILITÉ LÉGALE.

Si vous découvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message à debian-l10n-french.

pdf