La présentation est en train de télécharger. S'il vous plaît, attendez

La présentation est en train de télécharger. S'il vous plaît, attendez

GEF 243B Programmation informatique appliquée Expressions et opérateurs.

Présentations similaires


Présentation au sujet: "GEF 243B Programmation informatique appliquée Expressions et opérateurs."— Transcription de la présentation:

1 GEF 243B Programmation informatique appliquée Expressions et opérateurs

2 Revue Quelles sont les quatre types de base dans le langage C? Quelles sont les trois types intégraux dont nous sommes intéressé? Quelles sont les valeurs de vrai et faux en C? Pourquoi lutilisation des constantes littérales (tel que 5) nest-t-elle pas une bonne idée pour votre code. (au lieu dutiliser des constantes définies ou de mémoire)?

3 Une note… Parce que vous avez déjà une base en programmation dans ce cours, nous nous concentrons sur les différences entre ce que vous avez appris entre Matlab ou autre langage et C. Plusieurs choses que vous allez voir dans les prochaines semaines vont être une revue de ce que vous devriez déjà savoir avec quelques changements dans la syntaxe.

4 Synopsis Expressions en C primaire postfix préfix unaire Binaire Affectations Affectations composées Opérateurs spécifiques par type Opérateurs, précédence et associativité Conversion de type implicite

5 Expressions en C Il y a deux choses qui séparent C de plusieurs langages de programmation: Expressions Pointeurs Aujourdhui nous allons étudier la puissance que C nous donne pour les expressions

6 Expressions en C Une expression est une séquence dopérandes et dopérateurs qui se réduit en une seule valeur. Toutes les points suivants sont des expressions valides (a + b) a++ --c x = a + b + c y *= z !(a > b || c) -a

7 Expressions en C a, 5, (5 + a – z) a , t || f x = y b, !f, -a

8 Lexpression postfix Vous êtes déjà familier avec ceci: a++ Ex.: Nous voulons que x ait la valeur de a et que ensuite, a soit auto incrémenté après laffectation Dans plusieurs langages: (valeur initiale de a = 10) x = a.. Valeur de a et x 10 a = a a = 11 En C: x = a++; // même résultat quen haut

9 Lexpression unaire Vous êtes aussi familier avec cela: ++a Ex.: Nous voulons que x ait la valeur de a mais seulement après que a ait été incrémenté Dans plusieurs langages: (valeur initiale de a = 10) a = a a = 11 x = a.. Valeur de a et x 11 En C: x = ++a; // même résultat quen haut

10 Lexpression unaire Mais saviez vous que? x = -a //si a = 10 x = -10 //si a = -10 x = 10 Et il y en a encore plus… sizeof() est aussi une expression unaire sizeof(int) sizeof(x) x = sizeof(3.1416) sizeof((a + b -1)+(2-18.3)) (int)x …

11 Lexpression binaire Un opérateur est placé entre deux expressions forme une expression binaire x + 1, y * 3 (z + 2) * y Deux expressions binaire Une assignation à une variable est une forme dexpression.

12 Affectations composées Vous connaissez lopérateur daffectation = Mais connaissez vous les affectations composées Compound expressionEquivalent expression x *= yx = x * y x /= yx = x / y x %= yx = x % y x += yx = x + y x -= yx = x - y

13 Opérateurs, précédence & associativité Vous connaissez déjà tout les opérateurs que vous allez avoir besoin en 243 de votre cours en Java Sauf pour les opérateurs de bits, dadresses et de pointeurs Comme vous lavez appris durant votre vie en Java, il y a un ordre de précédence entre les opérateurs. Si vous ne pouvez pas vous en souvenir, il y a un tableau sur la couverture intérieure de Forouzan.

14 Types revisités Souvenez-vous quun type définit deux choses: Un ensemble de valeurs et Un ensemble dopérateurs Les types intrinsèques en C void char bool Integers Short int, int, long int, long long int Réels Float, double, long double Nous allons examiner des opérateurs qui sont spécifiques pour certains types en C

15 Opérateurs spécifiques par type C inclus un ensemble dopérateurs arithmétiques, booléens et logiques Tel que mentionné plus tôt, la fonctionnalité des opérateurs dépend du type des données, variables Arithmétiques + - * / % Booléens & | ! && || ^ Logiques == != > = <=

16 Opérateurs valides pour void void na pas de valeurs et aucun opérateur void est très utile pour les pointeurs ce que nous voyons plus tard Opérateurs

17 Opérateurs valides pour bool Le type booléen ( bool ) est une adition récente à C int est utilisé pour stocker ce genre de données logiques Lutilisation du type bool requiert normalement linclusion de la bibliothèque stdbool.h Cependant, cette bibliothèque nest pas disponible pour BrickOS donc nous lavons inclus dans 243_lib.h Définit bool, true et false false est définit comme int 0 true est définit comme int 1 (1==1) true (1!=1) false (i=0) false

18 Opérateurs valides int et char int et char ont les mêmes opérateurs valides Arithmétiques: Addition + Soustraction - Multiplication* Division/ Modulo % Pré/post incré++ Pré/post décré-- Booléens: AND&& OR || NOT! AND par Bit& OR par Bit | XOR par Bit^

19 Opérateurs valides int et char int et char ont les mêmes opérateurs valides Logiques: Plus grand que > Plus petit que < Plus grand ou égal>= Plus petit ou égal<= Égal== Pas égal != ATTENTION: = ET == NE SONT PAS LA MÊME CHOSE

20 Notes sur les opérateurs int % modulo Retourne le reste de la division dentiers Ex: connaissant que 7/4 = 1 reste 3 7%4 retourne 3 7/4 retourne 1 Puissance: Il ny a pas dopérateurs de puissance en C ^ est un opérateur sur les bits ( XOR ) En MATLAB pour X 2 : x^2 En C pour X 2 on écrit : x * x Notez quil y a une fonction pow() dans

21 Opérateurs valides float float ont les mêmes opérateurs valides Arithmétiques: Addition + Soustraction - Multiplication* Division/ Modulo % Pré/post incré++ Pré/post décré-- Booléens: AND&& OR || NOT! AND par Bit& OR par Bit | XOR par Bit^

22 Opérateurs valides float float ont les mêmes opérateurs valides Logiques: Plus grand que > Plus petit que < Plus grand ou égal>= Plus petit ou égal<= Égal== Pas égal != ATTENTION: Avec les floats Nutilisez pas == pour en comparer deux 1.1e-19 nest pas exactement 0 Utilisez … fabs(x-y)<0.0001;

23 Opérateurs, précédence & associativité Associativité est utilisée pour déterminer lordre dans lequel les opérateurs de même précédence sont évalués dans une expression complexe La plus part des expressions utilise lassociativité de gauche, donc: 3 * 8 / 4 % 4 * 5 est équivalent à ((((3 * 8) / 4) % 4) * 5) Ou graphiquement:

24 Opérateurs, précédence & associativité Lassociativité de droite est seulement utilisée pour trois types dexpressions: Unary (cas simple), Ternary (prochain cours), et Associativité dexpressions daffectation a += b *= c -= 5 est le même que: (a = a + ( b = b * ( c = c – 5))) ou:

25 Opérateurs, précédence & associativité Souvenez-vous: premièrement précédence, ensuite associativité Si vous regardez la table de précédence, les expressions avec parenthèses sont au haut de la chaîne alimentaire. Quand vous avez un doute sur lordre implicite, utilisez les parenthèses La bonne chose dans lutilisation des parenthèses est … le compilateur les vérifie!

26 Effets secondaires Certains opérateurs modifient les valeurs des variables en mémoire Cette modification du contenu de la mémoire est appelé un effet secondaire Par exemple, x = ++a ; a deux effets: a est pré incrémenté x se voit assigné la nouvelle valeur de a

27 Problèmes pratique Les questions pour évaluer la précédence des expressions sont toujours sur les examens Si il y a de ces questions, on vous donne la table des précédences. Essayés ceci…

28 Quiz Time Quelle est la valeur de cette expression * 5 Si a = 3 et b = 5 quelles sont leurs valeurs après: x = --a + b++ ? b += a-- ? y = -b++ ? Si x est float, y int et z char quelle sont les types des expressions: x/(y+z) ? x * (double) y / z


Télécharger ppt "GEF 243B Programmation informatique appliquée Expressions et opérateurs."

Présentations similaires


Annonces Google