Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum. Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

APPLICATION DES SEMAPHORE POUR LA RESOLUTION DU PROBLEME DES TRAINS


Information sur la source

Catégorie :Systeme Classé sous : sémaphore, train, ressource critique, système, java Niveau : Débutant Date de création : 21/08/2008 Date de mise à jour : 21/08/2008 09:30:21 Vu / téléchargé: 3 500 / 268

Note :
Aucune note

Commentaire sur cette source (5)
Ajouter un commentaire et/ou une note

Description

Salut donc voila la source présenté ici et l'application des sémaphores pour la résolution du problème des train
Ce problème est posé lorsque plusieurs trains veux passer par une seul rail
J'ai utilisé une class sémaphore et autre qui implémente la class 'sémaphore'
 

Source

  • /**
  • * Algorithme d'une sémaphore
  • *
  • * @author YERMES MOHAMMED EL AMINE
  • *
  • * UNIVERSITE DE MASCARA
  • * @version 1.0 20/08/2008
  • */
  • class Semaphore {
  • protected int value = 0;
  • protected Semaphore() {value = 1;}
  • protected Semaphore(int valeur) {value = valeur;}
  • public synchronized boolean occupe() {
  • if (value>0) return false;
  • else return true;
  • }
  • /* public synchronized void signaler() {
  • value = value + 1;
  • notify();
  • }
  • public synchronized void initialise() {
  • value = value - 1;
  • }*/
  • public synchronized void P() {
  • value--;
  • if (value < 0) {
  • while (true) {
  • try {
  • wait();
  • break;
  • } catch (InterruptedException e) {
  • System.err.println
  • ("Semaphore.P()");
  • continue;
  • }
  • }
  • }
  • }
  • public synchronized void V() {
  • value++;
  • if (value <= 0) notify();
  • }
  • public synchronized int value() {
  • return value;
  • }
  • public synchronized String toString() {
  • return String.valueOf(value);
  • }
  • }
/**
 * Algorithme d'une sémaphore
 * 
 * @author YERMES MOHAMMED EL AMINE
 * 
 * UNIVERSITE DE MASCARA
 * @version 1.0 20/08/2008
 */


class Semaphore {

   protected int value = 0;

   protected Semaphore() {value = 1;}

   protected Semaphore(int valeur) {value = valeur;}


   public synchronized boolean occupe() { 
   	if (value>0) 	return false;
   	else		return true;
   }


  /* public synchronized void signaler() { 
   	value = value + 1;
   	notify();
   }

   public synchronized void initialise() { 
   	value = value - 1;
   }*/




   public synchronized void P() {
      value--;
      if (value < 0) {
         while (true) {  
            try {
               wait();
               break;      
            } catch (InterruptedException e) {
               System.err.println
                  ("Semaphore.P()");
               continue;
              }
         }
      }
   }

   public synchronized void V() { 
      value++;                    
      if (value <= 0) notify();
   }

   public synchronized int value() {
      return value;
   }

   public synchronized String toString() {
      return String.valueOf(value);
   }

}

Conclusion

J'attends vos remarques et suggestion MERCI de bien lire mon code
 

Fichier Zip

Pour les "Membres Club", vous pouvez télécharger directement un fichier contenu dans le zip sans télécharger le zip en entier !

Télécharger le zip

Commentaires et avis

signaler à un administrateur
Commentaire de Twinuts le 21/08/2008 09:30:04 administrateur CS

Salut,

je n'ai pas testé le tout mais à la lecture je ne vois rien qui justifie un niveau 'initié', je repasse le code en 'débutant'.

signaler à un administrateur
Commentaire de shaft_amine le 21/08/2008 12:38:45

Je pense que c'est a vous de juger ça DÉBUTANT OK

signaler à un administrateur
Commentaire de shaft_amine le 24/08/2008 13:30:26

J'attends vos commentaires et suggestions

signaler à un administrateur
Commentaire de LocalStone le 29/08/2008 23:30:21

Je suis pas un expert en multi-threading, mais d'après le peu que je vois, y a comme un soucis. Les sémaphores, c'est quelque chose à utiliser dans un langage de bas niveau (typiquement le C). Le Java a sa propre gestion des threads, avec les moniteurs. Je pense que t'auras plus d'explication sur Wikipedia.

signaler à un administrateur
Commentaire de shaft_amine le 29/08/2008 23:56:09

L'interet ici est l'utilisation des sémaphores pour la résolution du problème. si vous lancez les threads et vous laissez le JVM s'occupes d'eux .... sa résoud pas le problème "la notion des sections critique et ressources critiques"

Ajouter un commentaire

Discussions en rapport avec ce code source dans le forum

diagrammde de classes d'un système Java [ par umltest ] Bonjour! je dois modéliser un système que je dois mettre en place,c'est à dire que je dois faire un diagramme de classes! Le système en ques Awt Style Xp [ par moi4975 ] En essayant de trouver quelques différences sur AWT et SWING, j'ai trouvé ça sur internet :La contrainte de l'AWT, ou l'avantage (c'est à double tranc Java et les services système NT [ par mthierry ] Bonjour &#224; tous,Je d&#233;veloppe depuis quelques ann&#233;es en Java avec les outils Sun standard (Java2 sdk 1.5).J'aimerai savoir s'il est possi Insertion dans jList [ par Dezouille ] Bonjour&nbsp;&#224; tous,je suis vraiment d&#233;butant dans java que je suis en train de d&#233;couvrir. Je developpe avec Sun Java Studio Enterprise Les répertoires en java? [ par houda82 ] Bonjour tt le monde, je veux cr&#233;er un r&#233;pertoire syst&#232;me c'est a dire qui interagie directement avec le syst&#232;me avec le java, je n Implémentation d'un fichier système avec Java [ par MHaya ] Salut,Je veux implémenter un fichier système d'une distribution LINUX pour y faire des modifications et ceci via un programme utilisant le langage Jav java [ par isorile ] bonjour tout le monde;j'ai un probléme avec mon jbuilder.quand je crée un projet et une application ça marche mais désque je met un textarea (dans des help applet java [ par tusenslebouc ] // Decompiled by Jad v1.5.8g. Copyright 2001 Pavel Kouznetsov. // Jad home page: http://www.kpdus.com/jad.html // Decompiler options: packimports(3) Passer une variable du JSP au JAVA [ par aminos88 ] Bonjour, J'ai dans une page JSP String host="127.0.0.1" qui est situé dans une boucle for c a d elle elle change de valuer a chaque itération et j'a probleme sur ajax.. debutant.. :p [ par meksoft002 ] salut, Je developpe un "projet web" j2ee avec eclipse et je voudrais introduire ajax.. j'ai comencé a essayé un exemple (que j'ai copié depuis un sit


Nos sponsors

Sondage...

CalendriCode

Juillet 2009
LMMJVSD
  12345
6789101112
13141516171819
20212223242526
2728293031  

Consulter la suite du CalendriCode

Téléchargements

Logiciels à télécharger sur le même thème :

Comparez les prix Nouvelle version

Photothèque Nouveau !



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,499 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.