TP N°4

Télécharger au format pdf ou txt
Télécharger au format pdf ou txt
Vous êtes sur la page 1sur 2

UNIVERSIT HASSAN 1er

ECOLE NATIONALE DES SCIENCES APPLIQUEES


KHOURIBGA

Module : Programmation Java


Filire : GRT (2me anne)

TP N4: les Thread


Exercice 1:
Un "compteur" a un nom (Toto par exemple) et il compte de 1 n (nombre entier positif
quelconque). Il marque une pause alatoire entre chaque nombre (de 0 5000 millisecondes par
exemple).
Un compteur affiche chaque nombre (Toto affichera par exemple, "Toto: 3") et il affiche un
message du type "*** Toto a fini de compter jusqu' 10" quand il a fini.
1) Ecrivez la classe compteur et testez-la en lanant plusieurs compteurs qui comptent jusqu' 10.
Voyez celui qui a fini le plus vite.
2) Modifiez la classe Compteur pour que chaque compteur affiche son ordre d'arrive : le message
de fin est du type : "Toto a fini de compter jusqu' 10 en position 3".

Exercice 2 :
Ci-dessous 2 classes Compte (correspond un compte bancaire) et Operation (thread qui
effectue des oprations sur un compte bancaire).
Problme :
Operation effectue des oprations qui devraient laisser le solde du compte inchang, et pourtant,
aprs un moment, le solde ne reste pas 0.
1- Modifiez le code pour empcher ce problme.
2- Dans le code de la classe Operation, remplacez l'opration nulle par 2 oprations ajouter et
retirer qui devraient elles aussi laisser le solde du compte 0 (elles sont en commentaire dans le
code). Lancez l'excution et constatez le problme. Modifiez le code pour que a marche.
public class Compte {
private int solde = 0;
public void ajouter(int somme) {
solde += somme;
System.out.print(" ajoute " + somme);
}
public void retirer(int somme) {
solde -= somme;
System.out.print(" retire " + somme);
}
public void operationNulle(int somme) {
solde += somme;
System.out.print(" ajoute " + somme);
Said EL KAFHALI

Page 1/2

solde -= somme;
System.out.print(" retire " + somme);
}
public int getSolde() {
return solde;
}
}
public class Operation extends Thread {
private Compte compte;
public Operation(String nom, Compte compte) {
super(nom);
this.compte = compte;
}
public void run() {
while (true) {
int i = (int) (Math.random() * 10000);
String nom = getName();
System.out.print(nom);
//
compte.ajouter(i);
//
compte.retirer(i);
compte.operationNulle(i);
int solde = compte.getSolde();
System.out.print(nom);
if (solde != 0) {
System.out.println(nom + ":**solde=" + solde);
System.exit(1);
}
}
}
public static void main(String[] args) {
Compte compte = new Compte();
for (int i = 0; i < 20; i++) {
Operation operation = new Operation("" + (char)('A' +
i), compte);
operation.start();
}
}
}

Exercice 3 : Les lecteurs / rdacteurs


Dans ce problme, des lecteurs et des rdacteurs travaillent sur un texte.
A tout moment, si un rdacteur crit, il doit tre seul (pas dautre rdacteur en train dcrire et aucun
lecteur en train de lire).
Les lecteurs, eux, peuvent lire en parallle.
Les lecteurs et les rdacteurs lisent/crivent pendant 500 ms et attendent pendant 500 ms.

Said EL KAFHALI

Page 2/2

Vous aimerez peut-être aussi

pFad - Phonifier reborn

Pfad - The Proxy pFad of © 2024 Garber Painting. All rights reserved.

Note: This service is not intended for secure transactions such as banking, social media, email, or purchasing. Use at your own risk. We assume no liability whatsoever for broken pages.


Alternative Proxies:

Alternative Proxy

pFad Proxy

pFad v3 Proxy

pFad v4 Proxy