Académique Documents
Professionnel Documents
Culture Documents
Langagec
Langagec
- Le Langage C – Partie I
E SAAD
Histoire du C
Origines
C a trois ancêtres : les langages CPL, BCPL et B.
BCPL : (pour Basic CPL) Cambridge en 1966 par Martin Richards. Version
siplifiée Ecriture d’un 1er Compilateur et de divers systèmes
d’exploitations
B : Ken Thompson vers 1970 dans les laboratoires Bell Version simplifiée
du BCPL
Histoire du C
C: développé par un collègue de Ken Thompson, Dennis Ritchie qui ajouta les
tableaux, les pointeurs, les nombres à virgule flottante, les structures... 1972
fut l'année de développement la plus productive et sans doute l'année de
baptême de C. En 1973, C fut suffisamment au point pour que 90% de
UNIX puisse être récrit avec.
C’est un texte écrit avec un éditeur de texte, respectant une certaine syntaxe et
stocké sous forme d'un ou plusieurs fichiers (généralement avec l'extension .c). A
l'opposé du langage assembleur, les instructions du langage C sont obligatoirement
encapsulées dans des fonctions et il existe une fonction privilégiée appelée main qui
est le point de départ de tout programme.
Exemple: main()
{
printf(’’Bonjour!’’);
}
Source.c
Compilation Objet.o Edition des liens Exécutable
2. Éléments de base
2.1 les fichiers include
Exemple:
# include <stdio.h>
main()
{
printf(’’Bonjour!’’);
}
Exemple:
# include <stdio.h> //pour pouvoir utiliser la fonction printf
main()
{
printf(’’Bonjour!’’);
}
/*Ce programme imprime la chaine de
caractère ‘’Bonjour!’’ à l’écran*/
2. Éléments de base
2.4 Les identificateurs
Ils peuvent être signés ou non signés : signed ou unsigned (unsigned int x;)
2. Éléments de base
a. Les Types Entiers
int (entier sur 32 bits : - 2 147 483 648 à 2 147 483 647)
long int ou long (entier sur 32 bits ou 64 bits, selon les machines)
Chacun des 3 peut être nuancé par l’utilisation du qualificatif unsigned pour ne
Float : codé sur 4 octets avec 1 bit de signe, 23 bits de mantisse et 8 bits
d'exposant
Double : codé sur 8 octets avec 1 bit de signe, 52 bits de mantisse et 11
bits d'exposant
Long : codé sur 10 octets avec 1 bit de signe, 64 bits de mantisse et 15 bits
d'exposant
NOTATION RESULTAT
\a cloche ou bip (alert ou audible bell)
\b Retour arrière (Backspace)
\f Saut de page (Form Feed)
\n Saut de Ligne (Line Feed)
\r Retour chariot (Carriage Return)
\t Tabulation horizontaLe (HorizontaL Tab)
\v Tabutation verticale (VerticaL Tab)
\\ \
\' ‘
\ '' ‘’
\? ?
2. Éléments de base
A propos du type booléen :
Pas de type booléen en C. Le type booléen est représenté par un entier. Il se comporte
comme la valeur booléenne vraie si cette valeur entière est non nulle.
Dans un contexte qui exige une valeur booléenne (comme les tests, par exemple), un
entier non nul équivaut à vrai et la valeur zero équivaut à faux
2. Éléments de base
2.6 Les Mots réservés
Les mots suivants sont réservés. Leur fonction est prévue par la syntaxe de C et ils ne
peuvent pas être utilisés dans un autre but :
Les opérateurs binaires ne sont à priori définis que pour deux opérandes ayant
le même type parmi: int, long int, float, double, long double et ils fournissent
un résultat de même type que leurs opérandes.
4. Opérateurs et Expressions
4.1 Opérateurs arithmétiques en C
De plus, il existe un opérateur de "modulo" noté % qui ne peut porter que sur des
entiers et qui fournit le reste de la division de son premier opérande par son
second. Par exemple, 11%4 vaut 3, 23%6 vaut 5
Conversions implicites :
On peut écrire des expressions mixtes dans lesquelles interviennent des opérandes
de types différents:
Int n,p; float x; n*x + p
(int * float) + int
Conversion implicite: int float ( float*float) + int
float + int
Même mécanisme : float + float float
Promotions numériques :
On a vu que les opérateurs numériques ne sont pas définis pour le types char et
short :
C prévoit que toute valeur char ou short soit d’abord convertie en int.
short n,p; float x; n*x + p
(short * float) + short
Conversion systématique: ( int * float) + int
Conversion implicite : float * float + int
float + float float
4. Opérateurs et Expressions
4.2 Opérateurs Relationnels
Par contre, C se distingue de la plupart des autres langages sur deux points:
1-le résultat de la comparaison est, non pas une valeur "booléenne" (on dit aussi
"logique") prenant l'une des deux valeurs vrai ou faux, mais un entier valant:
0 si le résultat de la comparaison est faux,
1 si le résultat de la comparaison est vrai.
Ainsi, la comparaison ci-dessus devient en fait une expression de type entier. Cela
signifie qu'elle pourra éventuellement intervenir dans des calculs arithmétiques;
4. Opérateurs et Expressions
4.2 Opérateurs Relationnels
Remarque: les opérateurs relationnels sont moins prioritaires que les opérateurs
arithmétiques ( x+y < a+2 (x+y) < (a+2) )
4. Opérateurs et Expressions
4.3 Opérateurs Logiques
Exemples:
n et p sont des entiers, le compilateur accepte des expression telles que:
n && p n||p if ( !n ) if (n == 0)
Remarque2: l’opérateur | | est moins prioritaire que &&. Tous deux sont de priorité
inférieure aux opérateurs arithmétique et relationnels
a<b && c<d équivaut à (a<b) && (c<d)
4. Opérateurs et Expressions
Nous avons déjà eu l'occasion de remarquer que : i = 5 était une expression qui
réalisait une action : l'affectation de la valeur 5 à i. Cet opérateur d'affectation (=)
peut faire intervenir d'autres expressions comme dans : c=b + 3
Priorité:
EXERCICES
5. Les Entées-Sorties Conversationnelles
Quelles sont les écritures autorisés pour des nombres fournis en données? Que se
Comment organiser les données lorsque l’on mélange les types numériques et les
types caractères?
d’informations?
La fonction printf a comme 1er argument une chaîne de caractères qui spécifie:
c : char: caractère affiché ''en clair" (convient aussi à short ou à int compte tenu
u : unsigned int (convient aussi à unsigned char ou à unsigned short, compte tenu
ld : long
lu : unsigned long
5.1 Les possibilités de la fonction printf
f : double ou float écrit en notation "décimale" avec six chiffres après le point
Les entiers sont affichés par défaut sans espaces avant ou après. Les flottants avec six
chiffres après le point.
Pour agir sur l’affichage un nombre est placé après % et précise le nombre de
caractère minimum à utiliser.
Exemples: printf("%3d" , n );
n = 20 ^20
n=3 ^^3
n = 2358 2358
n = -5200 -5200
5.1 Les possibilités de la fonction printf
Exemples: printf("%f" , x );
x = 1.2345 1.234500
x = 12.3456789 12.345678
printf("%10f" , x );
x = 1.2345 ^^1.234500
x = 1.2345E5 123450.000000
printf("%e" , x );
x = 1.2345 1.234500e+000
x = 123.45 1.234500e+002
5.1 Les possibilités de la fonction printf
Exemples: printf("%10.3f" , x );
x = 1.2345 ^^^^^1.235
x = 1.2345E3 ^^1234.500
x = 1.2345E7 12345000.000
Remarques:
Cadrage de l’affichage à gauche printf("%-10.3f" , x ); x = 1.2345 1.235^^^^^
- Le caractère * figurants à la place d’un gabarit ou une précision signifie que la valeur
effective est fournie dans la liste des arguments de printf:
printf("%8.*f" , n, x ); n=1; x=1.2345 ^^^^^1.2
- La fonction printf fournit une valeur de retour (nombre de caractère affichés)
5.1 Les possibilités de la fonction printf
c : char
d : int
u : unsigned int
hd : short int
hu : unsigned short
ld : long
lu : unsigned long
5.1 Les possibilités de la fonction scanf
Lorsque scanf attend des données, l’information frappée au clavier est rangée
exploré caractère par caractère au fur et à mesure des besoins. Certains caractères
123@
@
^25 n = 12 p=25
scanf("%d%c" , &n, &c );
12^a@ n = 12 c=‘ ‘
5.1 Les possibilités de la fonction scanf
Le traitement d’un code de format s’interrompe soit à la rencontre d’un séparateur, soit
lorsque le nombre de caractère indiqué a été atteint !!
12@
25@ n = 12 p=25
5.1 Les possibilités de la fonction scanf
Un espace entre deux codes de format demande à scanf de faire avancer le pointeur au
prochain caractère différent d’un séparateur !!
Un arrêt prématuré de scanf a lieu dans le cas où scanf n’est pas en mesur de fabriquer
une valeur adéquate !!
5.1 Les possibilités de la fonction scanf
if (condition réalisée )
{ liste d'instructions }
else
{ autre série d'instructions }
Remarques :
la condition doit être entre des parenthèses
il est possible de définir plusieurs conditions à remplir avec les
opérateurs ET et OU (&& et ||)
Par exemple l'instruction suivante teste si les deux conditions sont
vraies : if ((condition1)&&(condition2))L'instruction suivante exécutera
les instructions si l'une ou l'autre des deux conditions est vraie : if
((condition1)||(condition2))
Les boucles
Par exemple :
int main()
{
int a;
int b;
printf("a=");
scanf("%d",&a);
printf("b=");
scanf("%d",&b);
if(a>b)
{
printf("a est max");
}
if(a<b)
{
printf("b est max");
}
if(a==b)
{
printf("a est egal a b");
}
}
#include <stdio.h>
int main()
{
float a;
float b;
float x;
printf("a=");
scanf("%f",&a);
printf("b=");
scanf("%f",&b);
if(a==0 && b==0)
{
printf("la solution est R");
}
if(a==0 && b!=0)
{
printf("la solution esr l'ensemble vide");
}
if(a!=0)
{
printf("la solution est: %f",-(b/a));
}
}
#include <stdio.h>
#include <math.h>
int main()
{
float a;
printf("a=");
scanf("%f",&a);
float racine;
racine = sqrt(a);
printf("la racine de a est :%f",racine);
}
equation deuxièm degré
#include <stdio.h>
#include <math.h>
int main()
{
float a;
float b;
float c;
float p;
float delta;
float x;
float x1;
float x2;
float x3;
float racine;
printf("a=");
scanf("%f",&a);
printf("b=");
scanf("%f",&b);
printf("c=");
scanf("%f",&c);
delta =(b*b)-(4*a*c);
printf("delta est egal a: %f\n",delta); voir la suite (dispositiv 17)
La suite d l equation 2èm degré (dispositive 16)
racine=sqrt(delta);
x1=((-b) + racine)/(2*a);
x2=((-b) - racine)/(2*a);
x3=(-b)/(2*a);
if(delta>0)
{
printf("l'équation admet deux solution:\n");
printf("x1=%f\n",x1);
printf("x2=%f",x2);
}
if(delta<0)
{
printf("l'equation admet aucune solution dans R:\n");
}
if(delta==0)
{
printf("l'equation admet une seule solution :\n");
printf("x3= %f",x3);
}
}