Beruflich Dokumente
Kultur Dokumente
4 Les oprateurs 6
4.1 L'aectation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
4.2 Les oprateurs arithmtiques . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
4.3 Les oprateurs relationnels . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
4.4 Les oprateurs logiques boolens . . . . . . . . . . . . . . . . . . . . . . . . . . 7
4.5 Les oprateurs logiques bit bit . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
4.6 L'oprateur conditionnel ternaire . . . . . . . . . . . . . . . . . . . . . . . . . . 8
4.7 L'oprateur de conversion de type . . . . . . . . . . . . . . . . . . . . . . . . . . 8
4.8 La concatnation de chanes de caractres . . . . . . . . . . . . . . . . . . . . . 9
4.9 Rgles de priorit des oprateurs . . . . . . . . . . . . . . . . . . . . . . . . . . 9
5 Le branchement conditionnel 10
6 Les boucles 11
6.1 Boucle while . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
6.2 Boucle do-while . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
6.3 Boucle for . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
8 Fonctions 12
8.1 Dnition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
8.2 La fonction main . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
9 Les enregistrements 14
1
10 Les tableaux 15
11 Les fonctions mathmatiques 16
12 Le systme de chiers d'Unix/Linux 17
12.1 Les principales commandes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
12.2 Les expansions d'arguments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
12.3 Redirection des entres-sorties . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
2
1 La structure gnrale d'un programme
1.1 Programme sans enregistrements
class NomProgramme
{
// dclaration des variables globales
static type nomVariable;
class NomEnregistrement
{
// dclaration des champs
type nomChamp;
}
class NomProgramme
{
...
public static void main(String[] args)
{
...
}
}
3
2 Les composants lmentaires de Java
2.1 Les identicateurs
Un identicateur est une suite de caractres parmi :
les lettres (minuscules ou majuscules),
les chires,
le blanc soulign (_),
le dollar ($).
Les majuscules et minuscules sont direncies.
Conventions.
noms de variables : viter les noms commenant par _ ou par $ car ils sont habituelle-
ment rservs respectivement aux variables systmes et aux variables d'un code gnr
automatiquement ;
noms de fonctions : juxtaposer un verbe en minuscule et un nom dbutant par une
majuscule (par exemple, parcourirListe) ;
noms d'enregistrements et noms de programmes : commencer par une majuscule.
4
3 Les types primitifs
type taille (en bits) intervalle des valeurs valeur par dfaut
byte 8 [27 ; 27 [ 0
short 16 [215 ; 215 [ 0
int 32 [231 ; 231 [ 0
long 64 [263 ; 263 [ 0
char 16 [\u0000; \uffff] \u0000
boolean 1 {false, true} false
float 32 [1.4E 45; 3.4028235E38] 0
double 64 [4.9E 324; 1.7917931348623157E308] 0
5
3.5 Les constantes symboliques
Il est souvent souhaitable de donner un nom une constante plutt que d'utiliser sa valeur
littrale. Pour cela, on la dclare comme suit et on note gnralement son identicateur en
majuscules, par exemple
final int REPONSE = 42;
4 Les oprateurs
4.1 L'aectation
variable = expression
Cette expression a pour eet d'valuer expression et d'aecter la valeur obtenue variable.
De plus, cette expression possde une valeur, qui est celle d'expression. Ainsi, l'expression i
= 5 vaut 5.
L'aectation eectue une conversion de type implicite : la valeur de l'expression (terme de
droite) est convertie dans le type du terme de gauche. Cette conversion est possible uniquement
si elle s'eectue vers un type de taille suprieure celle du type de dpart :
byte short int long float double
char
Ces conversions sont sans perte de prcision, sauf celles de int et long en float et double
qui peuvent parfois entraner des arrondis.
6
L'oprateur % est le reste de la division euclidienne. Si l'un des deux oprandes est
ngatif, le signe du reste est celui du dividende. Cet oprateur s'applique aussi des
ottants. Dans ce cas, la valeur r de a % b est donne par r = a - bq o q = b ba c.
Notons enn qu'il n'y a pas d'oprateur eectuant l'lvation la puissance. De faon gnrale,
il faut utiliser la fonction pow(x,y) de la classe java.lang.Math pour calculer xy .
7
L'oprateur unaire ~ change la valeur de chaque bit d'un entier. Le dcalage droite a >> n
et gauche a << n eectuent respectivement une division et une multiplication par 2n quand
ils oprent sur un entier a positif, o n est pris modulo 32 pour les int et modulo 64 pour
les long. Quand a est un entier ngatif, le dcalage droite a >> n propage le bit de signe
(on remplit les n positions de poids fort avec des 1). Par contre, le dcalage droite sans
propagation du signe, a >>> n, propage des zros.
reprsentation reprsentation
dcimale binaire
a 77 00000000000000000000000001001101
b 23 00000000000000000000000000010111
a & b 5 00000000000000000000000000000101
a | b 95 00000000000000000000000001011111
a ^ b 90 00000000000000000000000001011010
~a -78 11111111111111111111111110110010
b << 5 736 00000000000000000000001011100000
b >> 2 5 00000000000000000000000000000101
b >> 3 2 00000000000000000000000000000010
b >> 32 23 00000000000000000000000000010111
c -33 11111111111111111111111111011111
c >> 2 -9 11111111111111111111111111110111
c >>> 2 1073741815 00111111111111111111111111110111
8
4.8 La concatnation de chanes de caractres
L'oprateur + appliqu deux objets de type String dsigne la concatnation de chanes
de caractres. Ds que l'un des deux oprandes est de type String, l'autre est converti en
String.
Par exemple, dans
int i = 3;
System.out.println("i = " + i);
la chane de caractres constante "i = " est concatne avec la valeur de la variable i convertie
en chane de caractres.
oprateurs
++ -- -(unaire) ~ ! (type)
* / %
+ -(arithmtiques) +(String)
<< >> >>>
< <= > >= instanceof
== !=
&(et bit--bit)
^
|
&&
||
?:
= *= /= %= += -= <<= >>= >>>= &= ^= |=
Notons que les oprateurs logiques bit--bit sont moins prioritaires que les oprateurs
relationnels. Cela implique que dans des tests sur les bits, il faut parenthser les expressions.
9
5 Le branchement conditionnel
La forme la plus gnrale est :
if ( expression )
{
instruction-1
}
else
{
instruction-2
}
expression est value. Si elle vaut true, instruction-1 est excute, sinon instruction-2
est excute.
Le bloc
else
{
instruction-2
}
est facultatif. Chaque instruction peut ici tre un bloc d'instructions.
Par ailleurs, on peut imbriquer un nombre quelconque de tests, ce qui conduit :
if ( expression-1 )
{
instruction-1
}
else if ( expression-2 )
{
instruction-2
..
.
}
else if ( expression-n )
{
instruction-n
}
else
{
instruction-
}
10
6 Les boucles
6.1 Boucle while
La syntaxe de while est la suivante :
while ( expression )
{
instruction
}
Tant que expression est vrie (i.e., vaut true), instruction est excute.
do
{
instruction
}
while ( expression );
Ici, instruction sera excute tant que expression vaut true. Cela signie donc que
instruction est toujours excute au moins une fois.
On doit comprendre cette boucle ainsi : expr-1 est la condition initiale de la boucle, expr-2
est la condition de poursuite de la boucle et expr-3 est une expression excute aprs chaque
tour de boucle. L'ide est que expr-1 reprsente l'tat initial d'un compteur dont la valeur
sera modie aprs chaque tour par expr-3, et la boucle continue tant que la condition expr-2
est vrie.
Par exemple,
for (int i=0; i<10; i=i+1)
{
System.out.println("Bonjour");
}
achera l'cran 10 fois le mot Bonjour suivi d'un retour la ligne.
Une version quivalente avec la boucle while serait :
11
int i = 0;
while (i < 10)
{
System.out.println("Bonjour");
i = i+1;
}
7.2 Lecture
On utilise les fonctions de la classe Ppl. Pour lire un entier entr au clavier et stocker sa
valeur dans la variable x, la syntaxe est
x = Ppl.readInt();
La classe Ppl contient galement les mthodes readChar, readDouble et readWord.
La fonction endOfInput retourne un boolen qui vaut true ds que le caractre de n de
chier est rencontr. Pour lire un ensemble d'entiers sur l'entre standard, on utilisera par
exemple :
do
{
x = Ppl.readInt();
// instructions
}
while (!Ppl.endOfInput());
8 Fonctions
8.1 Dnition
static type nomFonction( type1 para1, ..., typeN paraN)
{
dclarations de variables locales
instructions
return valeur;
}
type est le type de la valeur retourne par la fonction, donne comme argument de
return. Si la fonction ne retourne aucune valeur, elle est de type void et l'instruction
de retour la fonction appelante est return; (ou omise).
La fonction travaille sur une copie des valeurs de ses arguments.
12
Les mthodes dynamiques, elle, ne sont pas prcdes du mot-clef static.
Par exemple,
static long facto(int n)
{
long resultat = 1;
for (int i=2; i<=n; i=i+1)
{
resultat = resultat * i;
}
return resultat;
}
n'est rien d'autre que la fonction factorielle.
Il est possible de dnir des fonctions ayant le mme nom quand leur nombre d'arguments
ou le type de leurs arguments dirent.
Les arguments de main sont des chanes de caractres, ranges dans le tableau args. Il s'agit
des dirents mots passs en arguments de la commande java NomClass. L'lment args[0]
correspond au premier argument, et non au nom de la classe. Pour convertir les arguments de
main de type String en l'un des types primitifs, par exemple int, on utilise la fonction
int Integer.parseInt(String str)
ou, de manire quivalente Boolean.parseBoolean, Byte.parseByte, Short.parseByte,
Long.parseLong, Float.parseFloat, Double.parseDouble.
Par exemple, si l'on veut excuter un programme avec comme paramtres une chanes de
caractres, un nombre entier puis nouveau une chane de caractres, nous aurons la fonction
main suivante :
Ainsi, si notre programme se nomme Prog, on pourra l'appeler par la ligne de commande
java Prog France 91128 Palaiseau
13
9 Les enregistrements
Dnition
class NomEnregistrement
{
// dclaration des champs
[final] type nomChamp;
}
Comme pour les variables, il faut qualier de final un champ pour qu'il soit constant.
Constructeurs
On peut dnir d'autres constructeurs :
Le constructeur est une fonction qui porte le mme nom que l'enregistrement ;
Le type de l'objet retourn n'est pas mentionn, et il n'y a pas d'instruction return;
Il permet par exemple d'aecter les champs de l'objet construit, dsign par this.
Par exemple,
class Point
{
double abscisse;
double ordonnee;
Point(double x, double y)
{
abscisse = x;
ordonnee = y;
}
}
14
On appelle alors ce constructeur par Point p = new Point(42, 55.5);
Remarquons que l'on peut crire le constructeur ainsi :
Point(double abscisse, double ordonnee)
{
this.abscisse = abscisse;
this.ordonnee = ordonnee;
}
Dans ce cas, l'utilisation du mot-cl this est requise pour distinguer les arguments des
champs de l'enregistrement. Ainsi, this.abscisse correspond au champ abscisse d'un en-
registrement de type Point allou par le constructeur. La variable abscisse correspond, elle,
l'argument abscisse du constructeur.
10 Les tableaux
Dclaration
type[] nomTableau;
On peut galement initialiser un tableau sa dclaration :
type[] nomTableau = {liste des lments};
o les lments de la liste sont spars par des virgules.
Allocation
nomTableau = new type[expr];
o expr est une expression dont la valeur est un entier dnissant la longueur du tableau, i.e.
son nombre d'lments.
Tableaux multi-dimensionnels
La dclaration d'un tableau deux dimensions est de la forme
type[][] nomTableau;
et l'accs un lment se fait par nomTableau[i][j].
nomTableau[i] dsigne la ligne d'indice i du tableau. On peut allouer toutes les lignes
simultanment si elles ont la mme taille :
tab = new int[nbLignes][nbCol];
15
ou allouer les lignes sparment, par exemple pour un tableau triangulaire :
tab = new int[nbLignes][];
for (int i=0; i< tab.length; i=i+1)
tab[i] = new int[i+1];
16
long min (long a, long b)
float min (float a, float b)
double min (double a, double b)
double random () retourne un nombre alatoire de [0; 1[
17
supprime le ou les chiers donns en arguments.
pwd
Print Working Directory
ache le rpertoire courant.
18