Bibliothèque standard C - Guide rapide

le assert.h le fichier d'en-tête de la bibliothèque standard C fournit une macro appelée assert qui peut être utilisé pour vérifier les hypothèses faites par le programme et imprimer un message de diagnostic si cette hypothèse est fausse.

La macro définie assert fait référence à une autre macro NDEBUGqui ne fait pas partie de <assert.h>. Si NDEBUG est défini comme un nom de macro dans le fichier source, au point où <assert.h> est inclus, leassert macro est définie comme suit -

#define assert(ignore) ((void)0)

Macros de bibliothèque

Voici la seule fonction définie dans l'en-tête assert.h -

Sr.No. Description de la fonction
1 assert void (expression int)

Il s'agit en fait d'une macro et non d'une fonction, qui peut être utilisée pour ajouter des diagnostics dans votre programme C.

le ctype.h Le fichier d'en-tête de la bibliothèque standard C déclare plusieurs fonctions utiles pour tester et mapper des caractères.

Toutes les fonctions acceptent int en tant que paramètre, dont la valeur doit être EOF ou représentable sous forme de caractère non signé.

Toutes les fonctions renvoient non nul (vrai) si l'argument c satisfait la condition décrite, et zéro (faux) sinon.

Fonctions de la bibliothèque

Voici les fonctions définies dans l'en-tête ctype.h -

Sr.No. Description de la fonction
1 int isalnum (int c)

Cette fonction vérifie si le caractère passé est alphanumérique.

2 int isalpha (int c)

Cette fonction vérifie si le caractère passé est alphabétique.

3 int iscntrl (int c)

Cette fonction vérifie si le caractère passé est un caractère de contrôle.

4 int isdigit (int c)

Cette fonction vérifie si le caractère passé est un chiffre décimal.

5 int isgraph (int c)

Cette fonction vérifie si le caractère passé a une représentation graphique en utilisant les paramètres régionaux.

6 int islower (int c)

Cette fonction vérifie si le caractère passé est une lettre minuscule.

sept int isprint (int c)

Cette fonction vérifie si le caractère passé est imprimable.

8 int ispunct (int c)

Cette fonction vérifie si le caractère passé est un caractère de ponctuation.

9 int isspace (int c)

Cette fonction vérifie si le caractère passé est un espace blanc.

dix int isupper (int c)

Cette fonction vérifie si le caractère passé est une lettre majuscule.

11 int isxdigit (int c)

Cette fonction vérifie si le caractère passé est un chiffre hexadécimal.

La bibliothèque contient également deux fonctions de conversion qui acceptent et retournent un "int".

Sr.No. Description de la fonction
1 int tolower (int c)

Cette fonction convertit les lettres majuscules en minuscules.

2 int toupper (int c)

Cette fonction convertit les lettres minuscules en majuscules.

Classes de personnages

Sr.No. Classe de personnage et description
1

Digits

Il s'agit d'un ensemble de nombres entiers {0, 1, 2, 3, 4, 5, 6, 7, 8, 9}.

2

Hexadecimal digits

Il s'agit de l'ensemble {0 1 2 3 4 5 6 7 8 9 ABCDEF abcdef}.

3

Lowercase letters

Il s'agit d'un ensemble de lettres minuscules {abcdefghijklmnopqrstu vwxyz}.

4

Uppercase letters

Il s'agit d'un ensemble de lettres majuscules {ABCDEFGHIJKLMNOPQRSTU VWXYZ}.

5

Letters

Il s'agit d'un ensemble de lettres minuscules et majuscules.

6

Alphanumeric characters

Il s'agit d'un ensemble de chiffres, de lettres minuscules et de lettres majuscules.

sept

Punctuation characters

Ceci est un ensemble de! "# $% & '() * +, -. /:; <=>? @ [\] ^ _` {|} ~

8

Graphical characters

Il s'agit d'un ensemble de caractères alphanumériques et de caractères de ponctuation.

9

Space characters

Il s'agit d'un ensemble de tabulation, nouvelle ligne, tabulation verticale, saut de page, retour chariot et espace.

dix

Printable characters

Il s'agit d'un ensemble de caractères alphanumériques, de caractères de ponctuation et de caractères d'espace.

11

Control characters

En ASCII, ces caractères ont les codes octaux 000 à 037 et 177 (DEL).

12

Blank characters

Ce sont des espaces et des tabulations.

13

Alphabetic characters

Il s'agit d'un ensemble de lettres minuscules et majuscules.

le errno.h le fichier d'en-tête de la bibliothèque standard C définit la variable entière errno, qui est défini par les appels système et certaines fonctions de la bibliothèque en cas d'erreur pour indiquer ce qui n'a pas fonctionné. Cette macro se développe en une lvalue modifiable de type int, elle peut donc être à la fois lue et modifiée par un programme.

le errnoest mis à zéro au démarrage du programme. Certaines fonctions de la bibliothèque C standard modifient sa valeur à une valeur différente de zéro pour signaler certains types d'erreur. Vous pouvez également modifier sa valeur ou remettre à zéro à votre convenance.

le errno.h Le fichier d'en-tête définit également une liste de macros indiquant différents codes d'erreur, qui se développeront en expressions constantes entières de type int.

Macros de bibliothèque

Voici les macros définies dans l'en-tête errno.h -

Sr.No. Macro et description
1 extern int errno

Il s'agit de la macro définie par les appels système et certaines fonctions de la bibliothèque en cas d'erreur pour indiquer ce qui n'a pas fonctionné.

2 Erreur de domaine EDOM

Cette macro représente une erreur de domaine, qui se produit si un argument d'entrée est en dehors du domaine, sur lequel la fonction mathématique est définie et errno est défini sur EDOM.

3 ERANGE Erreur de plage

Cette macro représente une erreur de plage, qui se produit si un argument d'entrée est en dehors de la plage, sur laquelle la fonction mathématique est définie et errno est défini sur ERANGE.

le float.hLe fichier d'en-tête de la bibliothèque standard C contient un ensemble de différentes constantes dépendant de la plate-forme liées aux valeurs à virgule flottante. Ces constantes sont proposées par ANSI C. Elles permettent de réaliser des programmes plus portables. Avant de vérifier toutes les constantes, il est bon de comprendre que le nombre à virgule flottante est composé des quatre éléments suivants -

Sr.No. Description des composants et composants
1

S

signe (+/-)

2

b

base ou base de la représentation de l'exposant, 2 pour binaire, 10 pour décimal, 16 pour hexadécimal, et ainsi de suite ...

3

e

exposant, un entier entre un minimum emin et un maximum emax.

4

p

precision, le nombre de chiffres de base b dans le significande.

Sur la base des 4 composants ci-dessus, une virgule flottante aura sa valeur comme suit -

floating-point = ( S ) p x be

or

floating-point = (+/-) precision x baseexponent

Macros de bibliothèque

Les valeurs suivantes sont spécifiques à l'implémentation et définies avec la directive #define, mais ces valeurs ne peuvent pas être inférieures à ce qui est donné ici. Notez que dans tous les cas, FLT fait référence au typefloat, DBL fait référence à double, et LDBL fait référence à long double.

Sr.No. Macro et description
1

FLT_ROUNDS

Définit le mode d'arrondi pour l'addition en virgule flottante et il peut avoir l'une des valeurs suivantes -

  • -1 - indéterminable
  • 0 - vers zéro
  • 1 - au plus proche
  • 2 - vers l'infini positif
  • 3 - vers l'infini négatif
2

FLT_RADIX 2

Ceci définit la représentation de base de l'exposant. Une base-2 est binaire, base-10 est la représentation décimale normale, base-16 est hexadécimale.

3

FLT_MANT_DIG

DBL_MANT_DIG

LDBL_MANT_DIG

Ces macros définissent le nombre de chiffres dans le nombre (dans la base FLT_RADIX).

4

FLT_DIG 6

DBL_DIG 10

LDBL_DIG 10

Ces macros définissent le nombre maximum de chiffres décimaux (base 10) pouvant être représentés sans changement après arrondi.

5

FLT_MIN_EXP

DBL_MIN_EXP

LDBL_MIN_EXP

Ces macros définissent la valeur entière négative minimale pour un exposant en base FLT_RADIX.

6

FLT_MIN_10_EXP -37

DBL_MIN_10_EXP -37

LDBL_MIN_10_EXP -37

Ces macros définissent la valeur entière négative minimale pour un exposant en base 10.

sept

FLT_MAX_EXP

DBL_MAX_EXP

LDBL_MAX_EXP

Ces macros définissent la valeur entière maximale pour un exposant en base FLT_RADIX.

8

FLT_MAX_10_EXP +37

DBL_MAX_10_EXP +37

LDBL_MAX_10_EXP +37

Ces macros définissent la valeur entière maximale pour un exposant en base 10.

9

FLT_MAX 1E+37

DBL_MAX 1E+37

LDBL_MAX 1E+37

Ces macros définissent la valeur maximale en virgule flottante finie.

dix

FLT_EPSILON 1E-5

DBL_EPSILON 1E-9

LDBL_EPSILON 1E-9

Ces macros définissent le chiffre le moins significatif représentable.

11

FLT_MIN 1E-37

DBL_MIN 1E-37

LDBL_MIN 1E-37

Ces macros définissent les valeurs minimales en virgule flottante.

Exemple

L'exemple suivant montre l'utilisation de quelques-unes des constantes définies dans le fichier float.h.

#include <stdio.h>
#include <float.h>

int main () {
   printf("The maximum value of float = %.10e\n", FLT_MAX);
   printf("The minimum value of float = %.10e\n", FLT_MIN);

   printf("The number of digits in the number = %.10e\n", FLT_MANT_DIG);
}

Compilons et exécutons le programme ci-dessus qui produira le résultat suivant -

The maximum value of float = 3.4028234664e+38
The minimum value of float = 1.1754943508e-38
The number of digits in the number = 7.2996655210e-312

le limits.hl'en-tête détermine diverses propriétés des différents types de variables. Les macros définies dans cet en-tête limitent les valeurs de divers types de variables comme char, int et long.

Ces limites spécifient qu'une variable ne peut stocker aucune valeur au-delà de ces limites, par exemple un caractère non signé peut stocker jusqu'à une valeur maximale de 255.

Macros de bibliothèque

Les valeurs suivantes sont spécifiques à l'implémentation et définies avec la directive #define, mais ces valeurs ne peuvent pas être inférieures à ce qui est donné ici.

Macro Valeur La description
CHAR_BIT 8 Définit le nombre de bits dans un octet.
SCHAR_MIN -128 Définit la valeur minimale d'un caractère signé.
SCHAR_MAX +127 Définit la valeur maximale d'un caractère signé.
UCHAR_MAX 255 Définit la valeur maximale d'un caractère non signé.
CHAR_MIN -128 Définit la valeur minimale du type char et sa valeur sera égale à SCHAR_MIN si char représente des valeurs négatives, sinon zéro.
CHAR_MAX +127 Définit la valeur du type char et sa valeur sera égale à SCHAR_MAX si char représente des valeurs négatives, sinon UCHAR_MAX.
MB_LEN_MAX 16 Définit le nombre maximal d'octets dans un caractère multi-octets.
SHRT_MIN -32768 Définit la valeur minimale pour un int court.
SHRT_MAX +32767 Définit la valeur maximale pour un int court.
USHRT_MAX 65535 Définit la valeur maximale d'un int court non signé.
INT_MIN -2147483648 Définit la valeur minimale d'un int.
INT_MAX +2147483647 Définit la valeur maximale d'un int.
UINT_MAX 4294967295 Définit la valeur maximale d'un int non signé.
LONG_MIN -9223372036854775808 Définit la valeur minimale d'un long int.
LONG_MAX +9223372036854775807 Définit la valeur maximale d'un long int.
ULONG_MAX 18446744073709551615 Définit la valeur maximale d'un long int non signé.

Exemple

L'exemple suivant montre l'utilisation de quelques-unes des constantes définies dans limits.h fichier.

#include <stdio.h>
#include <limits.h>

int main() {

   printf("The number of bits in a byte %d\n", CHAR_BIT);

   printf("The minimum value of SIGNED CHAR = %d\n", SCHAR_MIN);
   printf("The maximum value of SIGNED CHAR = %d\n", SCHAR_MAX);
   printf("The maximum value of UNSIGNED CHAR = %d\n", UCHAR_MAX);

   printf("The minimum value of SHORT INT = %d\n", SHRT_MIN);
   printf("The maximum value of SHORT INT = %d\n", SHRT_MAX); 

   printf("The minimum value of INT = %d\n", INT_MIN);
   printf("The maximum value of INT = %d\n", INT_MAX);

   printf("The minimum value of CHAR = %d\n", CHAR_MIN);
   printf("The maximum value of CHAR = %d\n", CHAR_MAX);

   printf("The minimum value of LONG = %ld\n", LONG_MIN);
   printf("The maximum value of LONG = %ld\n", LONG_MAX);
  
   return(0);
}

Compilons et exécutons le programme ci-dessus qui produira le résultat suivant -

The number of bits in a byte 8
The minimum value of SIGNED CHAR = -128
The maximum value of SIGNED CHAR = 127
The maximum value of UNSIGNED CHAR = 255
The minimum value of SHORT INT = -32768
The maximum value of SHORT INT = 32767
The minimum value of INT = -2147483648
The maximum value of INT = 2147483647
The minimum value of CHAR = -128
The maximum value of CHAR = 127
The minimum value of LONG = -9223372036854775808
The maximum value of LONG = 9223372036854775807

le locale.hl'en-tête définit les paramètres spécifiques à l'emplacement, tels que les formats de date et les symboles monétaires. Vous trouverez plusieurs macros définies avec une structure importantestruct lconv et deux fonctions importantes énumérées ci-dessous.

Macros de bibliothèque

Voici les macros définies dans l'en-tête et ces macros seront utilisées dans deux fonctions répertoriées ci-dessous -

Sr.No. Macro et description
1

LC_ALL

Définit tout.

2

LC_COLLATE

Affecte les fonctions strcoll et strxfrm.

3

LC_CTYPE

Affecte toutes les fonctions de caractère.

4

LC_MONETARY

Affecte les informations monétaires fournies par la fonction localeconv.

5

LC_NUMERIC

Affecte le formatage de la virgule décimale et les informations fournies par la fonction localeconv.

6

LC_TIME

Affecte la fonction strftime.

Fonctions de la bibliothèque

Voici les fonctions définies dans l'en-tête locale.h -

Sr.No. Description de la fonction
1 char * setlocale (int category, const char * locale)

Définit ou lit les informations dépendant de l'emplacement.

2 struct lconv * localeconv (void)

Définit ou lit les informations dépendant de l'emplacement.

Structure de la bibliothèque

typedef struct {
   char *decimal_point;
   char *thousands_sep;
   char *grouping;	
   char *int_curr_symbol;
   char *currency_symbol;
   char *mon_decimal_point;
   char *mon_thousands_sep;
   char *mon_grouping;
   char *positive_sign;
   char *negative_sign;
   char int_frac_digits;
   char frac_digits;
   char p_cs_precedes;
   char p_sep_by_space;
   char n_cs_precedes;
   char n_sep_by_space;
   char p_sign_posn;
   char n_sign_posn;
} lconv

Voici la description de chacun des champs -

Sr.No. Champ et description
1

decimal_point

Caractère de virgule décimale utilisé pour les valeurs non monétaires.

2

thousands_sep

Des milliers de caractères de séparation de lieu sont utilisés pour les valeurs non monétaires.

3

grouping

Chaîne qui indique la taille de chaque groupe de chiffres en quantités non monétaires. Chaque caractère représente une valeur entière, qui désigne le nombre de chiffres dans le groupe actuel. Une valeur de 0 signifie que la valeur précédente doit être utilisée pour le reste des groupes.

4

int_curr_symbol

Il s'agit d'une chaîne de symboles monétaires internationaux utilisés. Les trois premiers caractères sont ceux spécifiés par l'ISO 4217: 1987 et le quatrième est le caractère qui sépare le symbole monétaire de la quantité monétaire.

5

currency_symbol

Le symbole local utilisé pour la devise.

6

mon_decimal_point

Le caractère de point décimal utilisé pour les valeurs monétaires.

sept

mon_thousands_sep

Caractère de regroupement des milliers de places utilisé pour les valeurs monétaires.

8

mon_grouping

Chaîne dont les éléments définissent la taille du regroupement des chiffres en valeurs monétaires. Chaque caractère représente une valeur entière qui désigne le nombre de chiffres dans le groupe courant. Une valeur de 0 signifie que la valeur précédente doit être utilisée pour le reste des groupes.

9

positive_sign

Caractère utilisé pour les valeurs monétaires positives.

dix

negative_sign

Caractère utilisé pour les valeurs monétaires négatives.

11

int_frac_digits

Nombre de chiffres à afficher après la virgule décimale dans les valeurs monétaires internationales.

12

frac_digits

Nombre de chiffres à afficher après la virgule décimale dans les valeurs monétaires.

13

p_cs_precedes

Si égal à 1, alors le currency_symbol apparaît avant une valeur monétaire positive. Si égal à 0, alors le currency_symbol apparaît après une valeur monétaire positive.

14

p_sep_by_space

Si égal à 1, alors le currency_symbol est séparé par un espace d'une valeur monétaire positive. Si égal à 0, alors il n'y a pas d'espace entre le symbole currency_symbol et une valeur monétaire positive.

15

n_cs_precedes

Si égal à 1, alors le currency_symbol précède une valeur monétaire négative. Si égal à 0, alors le currency_symbol succède à une valeur monétaire négative.

16

n_sep_by_space

Si égal à 1, alors le currency_symbol est séparé par un espace d'une valeur monétaire négative. Si égal à 0, alors il n'y a pas d'espace entre le symbole currency_symbol et une valeur monétaire négative.

17

p_sign_posn

Représente la position du signe positif dans une valeur monétaire positive.

18

n_sign_posn

Représente la position du signe négatif dans une valeur monétaire négative.

Les valeurs suivantes sont utilisées pour p_sign_posn et n_sign_posn -

Valeur La description
0 Les parenthèses encapsulent la valeur et le symbole currency_symbol.
1 Le signe précède la valeur et le symbole currency_symbol.
2 Le signe succède à la valeur et au currency_symbol.
3 Le signe précède immédiatement la valeur et le symbole currency_symbol.
4 Le signe succède immédiatement à value et currency_symbol.

le math.hl'en-tête définit diverses fonctions mathématiques et une macro. Toutes les fonctions disponibles dans cette bibliothèque prennentdouble comme argument et retour double comme résultat.

Macros de bibliothèque

Il n'y a qu'une seule macro définie dans cette bibliothèque -

Sr.No. Macro et description
1

HUGE_VAL

Cette macro est utilisée lorsque le résultat d'une fonction peut ne pas être représentable sous forme de nombre à virgule flottante. Si la magnitude du résultat correct est trop grande pour être représentée, la fonction définit errno sur ERANGE pour indiquer une erreur de plage et renvoie une valeur particulière très grande nommée par la macro HUGE_VAL ou sa négation (- HUGE_VAL).

Si l'amplitude du résultat est trop petite, une valeur de zéro est renvoyée à la place. Dans ce cas, errno peut être défini ou non sur ERANGE.

Fonctions de la bibliothèque

Voici les fonctions définies dans l'en-tête math.h -

Sr.No. Description de la fonction
1 double acos (double x)

Renvoie l'arc cosinus de x en radians.

2 double asin (double x)

Renvoie l'arc sinus de x en radians.

3 double atan (double x)

Renvoie l'arc tangente de x en radians.

4 double atan2 (double y, double x)

Renvoie l'arc tangent en radians de y / x en fonction des signes des deux valeurs pour déterminer le quadrant correct.

5 double cos (double x)

Renvoie le cosinus d'un angle radian x.

6 double cosh (double x)

Renvoie le cosinus hyperbolique de x.

sept double sin (double x)

Renvoie le sinus d'un angle en radian x.

8 double sinh (double x)

Renvoie le sinus hyperbolique de x.

9 double tanh (double x)

Renvoie la tangente hyperbolique de x.

dix double exp (double x)

Renvoie la valeur de e élevé à la puissance xième.

11 double frexp (double x, int * exposant)

La valeur retournée est la mantisse et l'entier pointé par l'exposant est l'exposant. La valeur résultante est x = mantisse * 2 ^ exposant.

12 double ldexp (double x, exposant int)

Retour x multiplié par 2 élevé à la puissance de l'exposant.

13 double bûche (double x)

Renvoie le logarithme naturel (logarithme de base-e) de x.

14 double log10 (double x)

Renvoie le logarithme commun (logarithme en base 10) de x.

15 double modf (double x, double * entier)

La valeur renvoyée est le composant de fraction (partie après la décimale) et définit l'entier sur le composant entier.

16 double pow (double x, double y)

Renvoie x élevé à la puissance de y.

17 double sqrt (double x)

Renvoie la racine carrée de x.

18 double plafond (double x)

Renvoie la plus petite valeur entière supérieure ou égale à x.

19 fabs doubles (double x)

Renvoie la valeur absolue de x.

20 double étage (double x)

Renvoie la plus grande valeur entière inférieure ou égale à x.

21 double fmod (double x, double y)

Renvoie le reste de x divisé par y.

le setjmp.h l'en-tête définit la macro setjmp(), une fonction longjmp()et un type de variable jmp_buf, pour contourner l'appel de fonction normal et renvoyer la discipline.

Variables de la bibliothèque

Voici le type de variable défini dans l'en-tête setjmp.h -

Sr.No. Variable et description
1

jmp_buf

Il s'agit d'un type de tableau utilisé pour contenir des informations pour la macro setjmp() et fonction longjmp().

Macros de bibliothèque

Il n'y a qu'une seule macro définie dans cette bibliothèque -

Sr.No. Macro et description
1 int setjmp (environnement jmp_buf)

Cette macro enregistre l' environnement actuel dans la variableenvironment pour une utilisation ultérieure par la fonction longjmp(). Si cette macro retourne directement de l'appel de la macro, elle renvoie zéro mais si elle retourne d'unlongjmp() appel de fonction, une valeur différente de zéro est renvoyée.

Fonctions de la bibliothèque

Voici la seule fonction définie dans l'en-tête setjmp.h -

Sr.No. Description de la fonction
1 void longjmp (environnement jmp_buf, valeur int)

Cette fonction restaure l'environnement sauvegardé par le dernier appel à setjmp() macro dans le même appel du programme avec le correspondant jmp_buf argument.

le signal.h l'en-tête définit un type de variable sig_atomic_t, deux appels de fonction et plusieurs macros pour gérer différents signaux signalés lors de l'exécution d'un programme.

Variables de la bibliothèque

Voici le type de variable défini dans le signal d'en-tête: h -

Sr.No. Variable et description
1

sig_atomic_t

C'est de inttype et est utilisé comme variable dans un gestionnaire de signaux. Il s'agit d'un type intégral d'objet accessible en tant qu'entité atomique, même en présence de signaux asynchrones.

Macros de bibliothèque

Voici les macros définies dans l'en-tête signal.h et ces macros seront utilisées dans deux fonctions répertoriées ci-dessous. leSIG_ des macros sont utilisées avec la fonction de signal pour définir les fonctions de signal.

Sr.No. Macro et description
1

SIG_DFL

Gestionnaire de signal par défaut.

2

SIG_ERR

Représente une erreur de signal.

3

SIG_IGN

Ignorer le signal.

le SIG les macros sont utilisées pour représenter un numéro de signal dans les conditions suivantes -

Sr.No. Macro et description
1

SIGABRT

Arrêt anormal du programme.

2

SIGFPE

Erreur en virgule flottante comme la division par zéro.

3

SIGILL

Opération illégale.

4

SIGINT

Signal d'interruption tel que ctrl-C.

5

SIGSEGV

Accès non valide au stockage comme une violation de segment.

6

SIGTERM

Demande de résiliation.

Fonctions de la bibliothèque

Voici les fonctions définies dans le signal d'en-tête: h -

Sr.No. Description de la fonction
1 void (* signal (int sig, void (* func) (int))) (int)

Cette fonction définit une fonction pour gérer le signal, c'est-à-dire un gestionnaire de signal.

2 int augmenter (int sig)

Cette fonction provoque le signal sigà générer. L'argument sig est compatible avec les macros SIG.

le stdarg.h l'en-tête définit un type de variable va_list et trois macros qui peuvent être utilisées pour obtenir les arguments dans une fonction lorsque le nombre d'arguments n'est pas connu, c'est-à-dire un nombre variable d'arguments.

Une fonction d'arguments variables est définie avec les points de suspension (, ...) à la fin de la liste de paramètres.

Variables de la bibliothèque

Voici le type de variable défini dans l'en-tête stdarg.h -

Sr.No. Variable et description
1

va_list

Il s'agit d'un type adapté pour contenir les informations nécessaires aux trois macros va_start(), va_arg() et va_end().

Macros de bibliothèque

Voici les macros définies dans l'en-tête stdarg.h -

Sr.No. Macro et description
1 void va_start (va_list ap, last_arg)

Cette macro s'initialise ap variable à utiliser avec la va_arg et va_endmacros. lelast_arg est le dernier argument fixe connu passé à la fonction, c'est-à-dire l'argument avant les points de suspension.

2 type va_arg (va_list ap, type)

Cette macro récupère l'argument suivant dans la liste des paramètres de la fonction de type type.

3 void va_end (va_list ap)

Cette macro autorise une fonction avec des arguments variables qui utilise le va_startmacro à retourner. Siva_end n'est pas appelée avant le retour de la fonction, le résultat n'est pas défini.

le stddef.hl'en-tête définit divers types de variables et macros. Beaucoup de ces définitions apparaissent également dans d'autres en-têtes.

Variables de la bibliothèque

Voici les types de variables définis dans l'en-tête stddef.h -

Sr.No. Variable et description
1

ptrdiff_t

Il s'agit du type intégral signé et est le résultat de la soustraction de deux pointeurs.

2

size_t

Il s'agit du type intégral non signé et est le résultat de la sizeof mot-clé.

3

wchar_t

Il s'agit d'un type intégral de la taille d'une constante de caractère large.

Macros de bibliothèque

Voici les macros définies dans l'en-tête stddef.h -

Sr.No. Macro et description
1 NUL

Cette macro est la valeur d'une constante de pointeur nul.

2 offsetof (type, membre-désignateur)

Il en résulte un entier constant de type size_t qui est le décalage en octets d'un membre de la structure depuis le début de la structure. Le membre est donné par membre-désignateur , et le nom de la structure est donné en type .

le stdio.h L'en-tête définit trois types de variables, plusieurs macros et diverses fonctions pour effectuer des entrées et des sorties.

Variables de la bibliothèque

Voici les types de variables définis dans l'en-tête stdio.h -

Sr.No. Variable et description
1

size_t

Il s'agit du type intégral non signé et est le résultat de la sizeof mot-clé.

2

FILE

Il s'agit d'un type d'objet adapté pour stocker des informations pour un flux de fichiers.

3

fpos_t

Il s'agit d'un type d'objet adapté pour stocker n'importe quelle position dans un fichier.

Macros de bibliothèque

Voici les macros définies dans l'en-tête stdio.h -

Sr.No. Macro et description
1

NULL

Cette macro est la valeur d'une constante de pointeur nul.

2

_IOFBF, _IOLBF et _IONBF

Ce sont les macros qui se développent en expressions constantes intégrales avec des valeurs distinctes et adaptées à l'utilisation comme troisième argument de la setvbuf fonction.

3

BUFSIZ

Cette macro est un entier, qui représente la taille du tampon utilisé par le setbuf fonction.

4

EOF

Cette macro est un entier négatif, ce qui indique que la fin de fichier a été atteinte.

5

FOPEN_MAX

Cette macro est un entier, qui représente le nombre maximum de fichiers que le système peut garantir d'ouvrir simultanément.

6

FILENAME_MAX

Cette macro est un entier, qui représente la plus longue longueur d'un tableau de caractères adapté pour contenir le nom de fichier le plus long possible. Si l'implémentation n'impose aucune limite, cette valeur doit être la valeur maximale recommandée.

sept

L_tmpnam

Cette macro est un entier, qui représente la plus longue longueur d'un tableau de caractères approprié pour contenir le nom de fichier temporaire le plus long possible créé par le tmpnam fonction.

8

SEEK_CUR, SEEK_END, et SEEK_SET

Ces macros sont utilisées dans le fseek fonction pour localiser différentes positions dans un fichier.

9

TMP_MAX

Cette macro est le nombre maximum de noms de fichiers uniques que la fonction tmpnam peut générer.

dix

stderr, stdin, et stdout

Ces macros sont des pointeurs vers des types FILE qui correspondent aux flux d'erreur standard, d'entrée standard et de sortie standard.

Fonctions de la bibliothèque

Voici les fonctions définies dans l'en-tête stdio.h -

Suivez la même séquence de fonctions pour mieux comprendre et utiliser Try it(Compilateur en ligne), car le fichier créé dans la première fonction sera utilisé dans les fonctions suivantes.
Sr.No. Description de la fonction
1 int fclose (FICHIER * flux)

Ferme le flux. Tous les tampons sont vidés.

2 void clearerr (FILE * flux)

Efface les indicateurs de fin de fichier et d'erreur pour le flux donné.

3 int feof (FILE * stream)

Teste l'indicateur de fin de fichier pour le flux donné.

4 int ferror (FILE * stream)

Teste l'indicateur d'erreur pour le flux donné.

5 int fflush (FICHIER * flux)

Vide le tampon de sortie d'un flux.

6 int fgetpos (FICHIER * flux, fpos_t * pos)

Obtient la position actuelle du fichier du flux et l'écrit dans pos.

sept FILE * fopen (const char * filename, const char * mode)

Ouvre le nom de fichier pointé par nom de fichier en utilisant le mode donné.

8 size_t fread (void * ptr, size_t size, size_t nmemb, FILE * stream)

Lit les données du flux donné dans le tableau pointé par ptr.

9 FILE * freopen (const char * filename, const char * mode, FILE * stream)

Associe un nouveau nom de fichier au flux ouvert donné et ferme en même temps l'ancien fichier dans le flux.

dix int fseek (FILE * stream, long int offset, int whence)

Définit la position du fichier du flux sur le décalage donné. L'argument offset signifie le nombre d'octets à rechercher à partir de la position whence donnée .

11 int fsetpos (FICHIER * flux, const fpos_t * pos)

Définit la position du fichier du flux donné à la position donnée. L'argument pos est une position donnée par la fonction fgetpos.

12 long int ftell (FILE * stream)

Renvoie la position actuelle du fichier du flux donné.

13 size_t fwrite (const void * ptr, size_t size, size_t nmemb, FILE * stream)

Écrit les données du tableau pointé par ptr dans le flux donné.

14 int remove (const char * nom de fichier)

Supprime le nom de fichier donné afin qu'il ne soit plus accessible.

15 int rename (const char * old_filename, const char * new_filename)

Provoque le changement du nom de fichier référencé par old_filename en new_filename.

16 annuler le rembobinage (flux FILE *)

Définit la position du fichier au début du fichier du flux donné.

17 void setbuf (FILE * stream, char * buffer)

Définit comment un flux doit être mis en mémoire tampon.

18 int setvbuf (FILE * stream, char * buffer, mode int, size_t size)

Une autre fonction pour définir comment un flux doit être mis en mémoire tampon.

19 FILE * tmpfile (void)

Crée un fichier temporaire en mode de mise à jour binaire (wb +).

20 char * tmpnam (char * str)

Génère et renvoie un nom de fichier temporaire valide qui n'existe pas.

21 int fprintf (FILE * stream, const char * format, ...)

Envoie la sortie formatée à un flux.

22 int printf (const char * format, ...)

Envoie la sortie formatée à stdout.

23 int sprintf (char * str, const char * format, ...)

Envoie la sortie formatée à une chaîne.

24 int vfprintf (FILE * stream, const char * format, va_list arg)

Envoie la sortie formatée à un flux à l'aide d'une liste d'arguments.

25 int vprintf (const char * format, va_list arg)

Envoie la sortie formatée à stdout à l'aide d'une liste d'arguments.

26 int vsprintf (char * str, const char * format, va_list arg)

Envoie la sortie formatée à une chaîne à l'aide d'une liste d'arguments.

27 int fscanf (FILE * stream, const char * format, ...)

Lit l'entrée formatée à partir d'un flux.

28 int scanf (const char * format, ...)

Lit l'entrée formatée depuis stdin.

29 int sscanf (const char * str, const char * format, ...)

Lit l'entrée formatée à partir d'une chaîne.

30 int fgetc (FICHIER * flux)

Obtient le caractère suivant (un caractère non signé) du flux spécifié et fait avancer l'indicateur de position du flux.

31 char * fgets (char * str, int n, FILE * stream)

Lit une ligne du flux spécifié et la stocke dans la chaîne pointée par str. Il s'arrête lorsque (n-1) caractères sont lus, le caractère de nouvelle ligne est lu ou la fin de fichier est atteinte, selon la première éventualité.

32 int fputc (int char, FILE * stream)

Écrit un caractère (un char non signé) spécifié par l'argument char dans le flux spécifié et avance l'indicateur de position du flux.

33 int fputs (const char * str, FILE * stream)

Écrit une chaîne dans le flux spécifié jusqu'au caractère nul, mais sans l'inclure.

34 int getc (FILE * flux)

Obtient le caractère suivant (un caractère non signé) du flux spécifié et fait avancer l'indicateur de position du flux.

35 int getchar (void)

Obtient un caractère (un caractère non signé) de stdin.

36 char * obtient (char * str)

Lit une ligne depuis stdin et la stocke dans la chaîne pointée par, str. Il s'arrête lorsque le caractère de nouvelle ligne est lu ou lorsque la fin du fichier est atteinte, selon la première éventualité.

37 int putc (int char, FILE * stream)

Écrit un caractère (un char non signé) spécifié par l'argument char dans le flux spécifié et avance l'indicateur de position du flux.

38 int putchar (caractère int)

Écrit un caractère (un caractère non signé) spécifié par l'argument char dans stdout.

39 int met (const char * str)

Écrit une chaîne dans stdout jusqu'au caractère nul, mais sans l'inclure. Un caractère de nouvelle ligne est ajouté à la sortie.

40 int ungetc (int char, FILE * stream)

Pousse le caractère char (un caractère non signé) sur le flux spécifié afin que le caractère suivant soit lu.

41 void perror (const char * str)

Imprime un message d'erreur descriptif sur stderr. Tout d'abord, la chaîne str est imprimée suivie de deux points puis d'un espace.

le stdlib.h L'en-tête définit quatre types de variables, plusieurs macros et diverses fonctions pour exécuter des fonctions générales.

Variables de la bibliothèque

Voici les types de variables définis dans l'en-tête stdlib.h -

Sr.No. Variable et description
1

size_t

Il s'agit du type intégral non signé et est le résultat de la sizeof mot-clé.

2

wchar_t

Il s'agit d'un type entier de la taille d'un wide constante de caractère.

3

div_t

Il s'agit de la structure renvoyée par le div fonction.

4

ldiv_t

Il s'agit de la structure renvoyée par le ldiv fonction.

Macros de bibliothèque

Voici les macros définies dans l'en-tête stdlib.h -

Sr.No. Macro et description
1

NULL

Cette macro est la valeur d'une constante de pointeur nul.

2

EXIT_FAILURE

Il s'agit de la valeur que la fonction exit doit renvoyer en cas d'échec.

3

EXIT_SUCCESS

Il s'agit de la valeur que la fonction de sortie doit renvoyer en cas de succès.

4

RAND_MAX

Cette macro est la valeur maximale renvoyée par la fonction rand.

5

MB_CUR_MAX

Cette macro est le nombre maximal d'octets dans un jeu de caractères multi-octets qui ne peut pas être plus grand que MB_LEN_MAX.

Fonctions de la bibliothèque

Voici les fonctions définies dans l'en-tête stlib.h -

Sr.No. Description de la fonction
1 double atof (const char * str)

Convertit la chaîne pointée par l'argument str en un nombre à virgule flottante (type double).

2 int atoi (const char * str)

Convertit la chaîne pointée par l'argument str en entier (type int).

3 atol entier long (const char * str)

Convertit la chaîne pointée par l'argument str en un entier long (type long int).

4 double strtod (const char * str, char ** endptr)

Convertit la chaîne pointée par l'argument str en un nombre à virgule flottante (type double).

5 long int strtol (const char * str, char ** endptr, int base)

Convertit la chaîne pointée par l'argument str en un entier long (type long int).

6 unsigned long int strtoul (const char * str, char ** endptr, int base)

Convertit la chaîne pointée par l'argument str en un entier long non signé (type unsigned long int).

sept void * calloc (size_t nitems, size_t taille)

Alloue la mémoire demandée et renvoie un pointeur vers elle.

8 void gratuit (void * ptr

Désalloue la mémoire précédemment allouée par un appel à calloc, malloc ou realloc .

9 void * malloc (taille_taille)

Alloue la mémoire demandée et renvoie un pointeur vers elle.

dix void * realloc (void * ptr, size_t taille)

Tente de redimensionner le bloc de mémoire pointé par ptr qui a été précédemment alloué avec un appel à malloc ou calloc .

11 annulation de l'annulation (annulation)

Provoque une interruption anormale du programme.

12 int atexit (void (* func) (void))

Provoque la fonction spécifiée func à appeler lorsque le programme se termine normalement.

13 void exit (statut int)

Provoque l'arrêt normal du programme.

14 char * getenv (const char * nom)

Recherche la chaîne d'environnement désignée par son nom et renvoie la valeur associée à la chaîne.

15 système int (const char * string)

La commande spécifiée par string est transmise à l'environnement hôte pour être exécutée par le processeur de commande.

16 void * bsearch (const void * key, const void * base, size_t nitems, size_t size, int (* compar) (const void *, const void *))

Effectue une recherche binaire.

17 void qsort (void * base, size_t nitems, size_t size, int (* compar) (const void *, const void *))

Trie un tableau.

18 int abs (int x)

Renvoie la valeur absolue de x.

19 div_t div (int numer, int denom)

Divise num (numérateur) par dénom (dénominateur).

20 labs longs int (long int x)

Renvoie la valeur absolue de x.

21 ldiv_t ldiv (long int numer, long int denom)

Divise num (numérateur) par dénom (dénominateur).

22 int rand (vide)

Renvoie un nombre pseudo-aléatoire compris entre 0 et RAND_MAX .

23 void srand (graine int non signée)

Cette fonction amorce le générateur de nombres aléatoires utilisé par la fonction rand.

24 int mblen (const char * str, size_t n)

Renvoie la longueur d'un caractère multi-octets pointé par l'argument str .

25 size_t mbstowcs (schar_t * pwcs, const char * str, size_t n)

Convertit la chaîne de caractères multi-octets pointée par l'argument str en tableau pointé par pwcs .

26 int mbtowc (whcar_t * pwc, const char * str, size_t n)

Examine le caractère multi-octets pointé par l'argument str .

27 size_t wcstombs (char * str, const wchar_t * pwcs, size_t n)

Convertit les codes stockés dans le tableau pwcs en caractères multi-octets et les stocke dans la chaîne str .

28 int wctomb (char * str, wchar_t wchar)

Examine le code qui correspond à un caractère multi-octets donné par l'argument wchar .

le string.h header defines one variable type, one macro, and various functions for manipulating arrays of characters.

Library Variables

Following is the variable type defined in the header string.h −

Sr.No. Variable & Description
1

size_t

This is the unsigned integral type and is the result of the sizeof keyword.

Library Macros

Following is the macro defined in the header string.h −

Sr.No. Macro & Description
1

NULL

This macro is the value of a null pointer constant.

Library Functions

Following are the functions defined in the header string.h −

Sr.No. Function & Description
1 void *memchr(const void *str, int c, size_t n)

Searches for the first occurrence of the character c (an unsigned char) in the first n bytes of the string pointed to, by the argument str.

2 int memcmp(const void *str1, const void *str2, size_t n)

Compares the first n bytes of str1 and str2.

3 void *memcpy(void *dest, const void *src, size_t n)

Copies n characters from src to dest.

4 void *memmove(void *dest, const void *src, size_t n)

Another function to copy n characters from str2 to str1.

5 void *memset(void *str, int c, size_t n)

Copies the character c (an unsigned char) to the first n characters of the string pointed to, by the argument str.

6 char *strcat(char *dest, const char *src)

Appends the string pointed to, by src to the end of the string pointed to by dest.

7 char *strncat(char *dest, const char *src, size_t n)

Appends the string pointed to, by src to the end of the string pointed to, by dest up to n characters long.

8 char *strchr(const char *str, int c)

Searches for the first occurrence of the character c (an unsigned char) in the string pointed to, by the argument str.

9 int strcmp(const char *str1, const char *str2)

Compares the string pointed to, by str1 to the string pointed to by str2.

10 int strncmp(const char *str1, const char *str2, size_t n)

Compares at most the first n bytes of str1 and str2.

11 int strcoll(const char *str1, const char *str2)

Compares string str1 to str2. The result is dependent on the LC_COLLATE setting of the location.

12 char *strcpy(char *dest, const char *src)

Copies the string pointed to, by src to dest.

13 char *strncpy(char *dest, const char *src, size_t n)

Copies up to n characters from the string pointed to, by src to dest.

14 size_t strcspn(const char *str1, const char *str2)

Calculates the length of the initial segment of str1 which consists entirely of characters not in str2.

15 char *strerror(int errnum)

Searches an internal array for the error number errnum and returns a pointer to an error message string.

16 size_t strlen(const char *str)

Computes the length of the string str up to but not including the terminating null character.

17 char *strpbrk(const char *str1, const char *str2)

Finds the first character in the string str1 that matches any character specified in str2.

18 char *strrchr(const char *str, int c)

Searches for the last occurrence of the character c (an unsigned char) in the string pointed to by the argument str.

19 size_t strspn(const char *str1, const char *str2)

Calculates the length of the initial segment of str1 which consists entirely of characters in str2.

20 char *strstr(const char *haystack, const char *needle)

Finds the first occurrence of the entire string needle (not including the terminating null character) which appears in the string haystack.

21 char *strtok(char *str, const char *delim)

Breaks string str into a series of tokens separated by delim.

22 size_t strxfrm(char *dest, const char *src, size_t n)

Transforms the first n characters of the string src into current locale and places them in the string dest.

The time.h header defines four variable types, two macro and various functions for manipulating date and time.

Library Variables

Following are the variable types defined in the header time.h −

Sr.No. Variable & Description
1

size_t

This is the unsigned integral type and is the result of the sizeof keyword.

2

clock_t

This is a type suitable for storing the processor time.

3

time_t is

This is a type suitable for storing the calendar time.

4

struct tm

This is a structure used to hold the time and date.

La structure tm a la définition suivante -

struct tm {
   int tm_sec;         /* seconds,  range 0 to 59          */
   int tm_min;         /* minutes, range 0 to 59           */
   int tm_hour;        /* hours, range 0 to 23             */
   int tm_mday;        /* day of the month, range 1 to 31  */
   int tm_mon;         /* month, range 0 to 11             */
   int tm_year;        /* The number of years since 1900   */
   int tm_wday;        /* day of the week, range 0 to 6    */
   int tm_yday;        /* day in the year, range 0 to 365  */
   int tm_isdst;       /* daylight saving time             */
};

Macros de bibliothèque

Voici les macros définies dans l'en-tête time.h -

Sr.No. Macro et description
1

NULL

Cette macro est la valeur d'une constante de pointeur nul.

2

CLOCKS_PER_SEC

Cette macro représente le nombre d'horloges du processeur par seconde.

Fonctions de la bibliothèque

Voici les fonctions définies dans l'en-tête time.h -

Sr.No. Description de la fonction
1 char * asctime (const struct tm * timeptr)

Renvoie un pointeur vers une chaîne qui représente le jour et l'heure de la structure timeptr.

2 clock_t clock (vide)

Renvoie le temps d'horloge du processeur utilisé depuis le début d'une ère définie par l'implémentation (normalement le début du programme).

3 char * ctime (const time_t * timer)

Renvoie une chaîne représentant l'heure locale en fonction de l'argument timer.

4 double difftime (time_t time1, time_t time2)

Renvoie la différence en secondes entre time1 et time2 (time1-time2).

5 struct tm * gmtime (const time_t * timer)

La valeur de la minuterie est décomposée en la structure tm et exprimée en temps universel coordonné (UTC) également appelé temps moyen de Greenwich (GMT).

6 struct tm * localtime (const time_t * timer)

La valeur de timer est décomposée dans la structure tm et exprimée dans le fuseau horaire local.

sept time_t mktime (struct tm * timeptr)

Convertit la structure pointée par timeptr en une valeur time_t en fonction du fuseau horaire local.

8 size_t strftime (char * str, size_t maxsize, const char * format, const struct tm * timeptr)

Formate l'heure représentée dans la structure timeptr selon les règles de formatage définies dans format et stockées dans str.

9 time_t time (time_t * timer)

Calcule l'heure actuelle du calendrier et l'encode au format time_t.