- Les structs
- Le type string
- Le type vector
- Flux sur un fichier de sortie
- Flux sur un fichier d’entrée
- Demo : copie d’un fichier et lien avec R1.02
Archives d’Auteur: alain
R1.01 – Amphi 10
- Gestion des erreurs de lecture
- Positionnement dans un flux
- Etat d’un flux
- Tri de tableau
- Tester ses programmes (V2)
R1.01 – Amphi 11
R1.01 – Amphi 12
Planning 2024-2025
Semaine du 2 septembre
- Amphi 01
- Amphi 02
- Amphi 03
Semaine du 9 septembre
- Amphi 04
- TD1
Semaine du 16 septembre
- Amphi 05
- Amphi 06
- TD2
- Mini test 1
Semaine du 23 septembre
- Amphi 07
- Amphi 08
- TD3
- TD4
- Mini test 2
Semaine du 30 septembre
Amphi 09Amphi 10- TD5
- Mini test 3
- TP1
- TD6 – partie #1
Semaine du 07 octobre
- TD6 – partie #2
- TP #2
Mini test #4
Semaine du 14 octobre
Mini test #5- TD7
- TP3 : lancement de la SAE #1.02
- Test Algo
- partie #1 QCM (environ 40 questions / 20 min)
- partie #2 (un gros exercice), le thème de cette année c’est quels sont les algorithmes utilisés par les bibliothèque Python;
- Document autorisé : 1 feuilles A4 (recto/verso) – sauf pour ceux qui on un justificatif des dysgraphie, auquel cas, ils pourront imprimé leur document autorisé.
Semaine du 21 octobre
- TD10
- TP4
- Amphi :
- Correction du test;
- Réponse aux questions relatives à la SAE
- Coding live d’une des réponses à la SAE (vous n’aurez plus le droit de l’utiliser)
- Le code fourni en amphi est disponible ici
- Amphi #9
- Le fichier contenant la liste des votants est disponible ici
Semaine du 4 novembre
Semaine du 11 novembre
Semaine du 18 novembre
Semaine du 25 novembre
- TP 12
- Soutenance SAE 1.02
Semaine du 2 décembre
Semaine du 9 décembre
Semaine du 16 décembre
M4104C – Exercice1 / La piscine
Dans cet exercice nous allons vous demander de modéliser le fonctionnement d’une piscine. Les clients de la piscine sont des threads, nous vous demandons donc d’écrire le code de ces threads correspondant au comportement décrit dans la suite de l’énoncé.
Un baigneur doit :
- Arriver à la piscine ;
- Prendre un panier ;
- Trouver cabine et entrer dedans afin de se déshabiller ;
- Libérer la cabine ;
- Aller nager
- Prendre une cabine et s’habiller ;
- Rendre son panier ;
- Quitter la piscine ;
Ressources critiques : certaines phases de ces activités mettent en jeu des ressources critiques, pour lesquelles les threads rentrent en compétitions :
- la piscine dispose d’un certain nombre NbPaniers de paniers dans lesquels les baigneurs laissent leurs habits pendant le temps de la baignade ;
- chaque baigneur se déshabille et se rhabille dans une cabine individuelle. La piscine dispose d’un nombre NbCabines de cabines.
Les phases de déshabillage et de rhabillage ne peuvent commencer que si certaines conditions sont réalisées :
- chaque baigneur doit disposer d’un panier et d’une cabine pour commencer à se déshabiller ;
- chaque baigneur ne doit disposer que d’une cabine pour commencer à se rhabiller.
Ces deux conditions sont donc éventuellement bloquantes.
Les fins des phases de déshabillage et de rhabillage ne sont pas bloquantes mais correspondent à la libération de ressources critiques :
- chaque baigneur rend sa cabine quand il a fini de se déshabiller ;
- chaque baigneur rend sa cabine et son panier quand il a fini de se rhabiller.
Le code du baigneur peut être le suivant :
//arrivée
sleep (XXX) ;
// déshabillage
DebutDeshabiller();
sleep(XXX);
FinDeshabiller();
//baignade
sleep (XXX) ;
// rhabillage
DebutRhabiller() ;
sleep(XXX) ;
FinRhabiller() ;
//départ
sleep (XXX) ;
Ecrire le corps des fonctions : DebutDeshabiller (), FinDeshabiller (), DebutRhabiller () et FinRhabiller () selon les spécifications précédentes.
M4104C – EXERCICE2 / Lecteur / rédacteur
A. Utilisation d’un unique sémaphore en exclusion mutuelle (Mut)
Coté lecteur :
T Lire ()
Mut.P();
T info = RetirerInfo ();
Mut.V ();
return info;
Coté rédacteur :
void Ecrire (const T & info)
Mut.P();
PoserInfo (info);
Mut.V();
Montrer que l’on peut obtenir un interblocage de processus.
B. Utilisation de plusieurs sémaphores
La solution ci-dessous est inspirée de celle vue en cours, malheureusement elle n’est pas fonctionnelle. Dites pourquoi et corrigez la.
Indication : on donnera toujours priorité aux lecteurs par rapport aux rédacteurs.
Init : MutRedPresent = 0 ; MutRedEcr = 0 ; MutLect = 0;
Coté lecteur :
MutRedPresent.P ();
MutLect.P();
T info = RetirerInfo ();
MutLect.V ();
return info ;
Coté rédacteur :
MutRedEcr.P();
PoserInfo (info) ;
MutRedEcr.V();
MutRedPresent.V ();
M4104C – EXERCICE3 / Le diner des philosophes
Problème :
La situation est la suivante :
- cinq philosophes (initialement mais il peut y en avoir beaucoup plus) se trouvent autour d’une table ;
- chacun des philosophes a devant lui un plat de spaghetti ;
- à gauche de chaque plat de spaghetti se trouve une fourchette.
Un philosophe n’a que trois états possibles :
- penser pendant un temps indéterminé ;
- être affamé (pendant un temps déterminé et fini sinon il y a famine) ;
- manger pendant un temps déterminé et fini.
Des contraintes extérieures s’imposent à cette situation :
- quand un philosophe a faim, il va se mettre dans l’état « affamé » et attendre que les fourchettes soient libres ;
- pour manger, un philosophe a besoin de deux fourchettes : celle qui se trouve à gauche de sa propre assiette, et celle qui se trouve à droite (c’est-à-dire les deux fourchettes qui entourent sa propre assiette) ;
- si un philosophe n’arrive pas à s’emparer d’une fourchette, il reste affamé pendant un temps déterminé, en attendant de renouveler sa tentative.
Le problème consiste à trouver un ordonnancement des philosophes tel qu’ils puissent tous manger, chacun à leur tour. Cet ordre est imposé par la solution que l’on considère comme celle de Dijkstra avec sémaphores ou Courtois avec des compteurs.
Le corps du processus philosophe peut être le suivant :
Philo(i)
{
while(true)
{
pense( );
prendre_fourchette( i );
manger ( );
poser_fourchette( i );
}
}
Conséquence, il faut écrire les fonctions prendre_fouchette () et poser_fourchette ().
A. Première solution
On prend un sémaphore par fourchette (un mutex fait aussi l’affaire), chaque sémaphore est initialisé à 1.
sem fourch[ N ] = {1,........1}
prendre_fourchette (int i)
{
fourch[i].P() ;
fourch[(i+1)% N].P() ;
}
poser_fourchette (int i)
{
fourch[i].V() ;
fourch[(i+1)% N].V() ;
}
Monter que cette solution peut provoquer un interblocage de processus.
B. Deuxième solution
On modifie la solution 1 de sorte que les philosophes ne puissent pas prendre tous en même temps la fourchette de droite.
On introduit pour cela un sémaphore dont le compteur est égal à N-1
Implémenter cette solution.
C. Troisième solution
C’est la même chose que la première solution sauf qu’un philosophe est gaucher et ceci afin d’éviter l’interblocage.
Implémenter cette solution.
D. Quatrième solution
On se centre ici sur les philosophes. Un sémaphore est attribué à chaque philosophe.
Etat = { PENSE , MANGE , A_FAIM}
Un philosophe qui veut prendre les fourchettes (donc manger) déclare qu’il a faim. Si l’un de ses deux voisins est en train de manger, il ne peut donc pas prendre les deux fourchettes pour l’instant et donc se met en attente. Si les deux philosophes à coté ne mangent pas alors il peut prendre les deux fourchettes et déclarer qu’il mange. Quand le philosophe a fini de manger, il déclare donc qu’il pense et regarde si ses deux voisins qui forcément ne pouvaient pas manger, en ont dès lors l’opportunité. Si c’est le cas il les réveille.
Implémenter cette solution.
M4104C – Planning
Semaine du 29 mars.
Mardi 30/03 mot de passe Xenophon lien 913 4829 5689
Semaine du 5 avril.
Mardi 30/03 mot de passe Cyropedie
Numéro de réunion : 944 3386 5180
lien
Lien pour les soutenances (voir page ametice du dept) :
M1103 TP6 (ULAM) – Exercice 1
Ecrire les fonctions ci-dessous :
bool estPremier (const unsigned & i); vector <unsigned> nbPremiersAvantN (const unsigned & N);
La fonction estPremier ()
teste si l’entier passé en paramètre est un premier.
La fonction nbPremiersAvantN ()
renvoie dans un tableau, tous les nombres premiers plus petit que le paramètre.