NOM
cfree - Libérer la mémoire allouéeBIBLIOTHÈ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).Interface | Attribut | Valeur |
cfree() | Sécurité des threads | MT-Safe /* Dans la glibc */ |
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 <[email protected]>, Thierry Vignaud <[email protected]>, François Micaux, Alain Portal <[email protected]>, Jean-Philippe Guérard <[email protected]>, Jean-Luc Coulon (f5ibh) <[email protected]>, Julien Cristau <[email protected]>, Thomas Huriaux <[email protected]>, Nicolas François <[email protected]>, Florentin Duneau <[email protected]>, Simon Paillard <[email protected]>, Denis Barbier <[email protected]>, David Prévot <[email protected]> et Jean-Pierre Giraud <[email protected]> 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 à [email protected]5 février 2023 | Pages du manuel de Linux 6.03 |