IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Java Discussion :

Ordonnancement Thread Java


Sujet :

Java

  1. #1
    Membre averti
    Inscrit en
    Octobre 2010
    Messages
    15
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 15
    Par défaut Ordonnancement Thread Java
    Je cherche à implémenter un ordonnanceur de thread en se basant sur l'algorithme d'ordonnancement Earliest Deadline First (EDF). Il s'agit d'un algorithme préemptif à priorité dynamique utilisé dans les systèmes temps réel. Il attribue une priorité à chaque thread en fonction de l'échéance de ce dernier. Plus l'échéance d'une tâche est proche, plus sa priorité est grande.

    J'ai attribuer à chaque thread une échéance et une priorité. Chaque thread crée est enregistré dans un vecteur global.

    S'il vous plait, pouvez vous m'indiquer comment implémenter l'ordonnanceur et quand est ce que je doit l'appeler, après la méthode start() ou au cours de la méthode run() ?

    Merci d'avance.

  2. #2
    Modérateur
    Avatar de dinobogan
    Homme Profil pro
    ingénieur
    Inscrit en
    Juin 2007
    Messages
    4 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : ingénieur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 4 073
    Par défaut
    La priorité d'un Thread est modifiable via la méthode setPriority.
    Tu devras réviser toutes les priorités des Threads à chaque création d'un nouveau Thread et à chaque changement d'échéance d'un Thread. Ces changements se feront dans le run de l'ordonnanceur.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java
    Que la force de la puissance soit avec le courage de ta sagesse.

  3. #3
    Membre averti
    Inscrit en
    Octobre 2010
    Messages
    15
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 15
    Par défaut
    Bonjour, merci de m'avoir répondu.

    Selon mon application la priorité d'un thread est de type double (elle est calculée en fonction de l'échéance). Alors que selon la méthode setPriority, la priorité doit être de type int !!!

  4. #4
    Modérateur
    Avatar de dinobogan
    Homme Profil pro
    ingénieur
    Inscrit en
    Juin 2007
    Messages
    4 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : ingénieur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 4 073
    Par défaut
    C'est à toi de faire l'interfaçage entre ta donnée brut et le type borné attendu par la méthode.
    La priorité d'un Thread est entre les bornes [MAX_PRIORITY;MIN_PRIORITY].

    Explique comment tu obtiens ta valeur en double.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java
    Que la force de la puissance soit avec le courage de ta sagesse.

  5. #5
    Membre éclairé
    Avatar de wafiwafi
    Profil pro
    Inscrit en
    Décembre 2008
    Messages
    500
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2008
    Messages : 500
    Par défaut
    Un livre "Java tête la première" traite bien ce cas et l'explique bien.

  6. #6
    Membre averti
    Inscrit en
    Octobre 2010
    Messages
    15
    Détails du profil
    Informations forums :
    Inscription : Octobre 2010
    Messages : 15
    Par défaut
    priorité = 1/échéance

    L'échéance d'un thread est calculée en fonction du temps d'arrivé au système, (CurrentTimeMillis()).

  7. #7
    Modérateur
    Avatar de dinobogan
    Homme Profil pro
    ingénieur
    Inscrit en
    Juin 2007
    Messages
    4 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : ingénieur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 4 073
    Par défaut
    Tu peux faire une simple règle de trois.
    Tu sais que la priorité calculée est un flottant entre 0 et 1.
    Tu sais que la priorité d'un Thread se situe entre MIN_PRIORITY et MAX_PRIORITY.

    La priorité à donnée à chaque Thread est donc :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    int priorite = (int)( MIN_PRIORITY + (MAX_PRIORITY - MIN_PRIORITY) / echeance );
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java
    Que la force de la puissance soit avec le courage de ta sagesse.

  8. #8
    Membre Expert
    Avatar de professeur shadoko
    Homme Profil pro
    retraité nostalgique Java SE
    Inscrit en
    Juillet 2006
    Messages
    1 257
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 76
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : retraité nostalgique Java SE

    Informations forums :
    Inscription : Juillet 2006
    Messages : 1 257
    Par défaut
    Là ma curiosité est piquée....
    Je crois que ceci ne va pas fonctionner complétement puisque les stratégies de l'ordonnanceur sont dépendantes du système et faire joujou avec les priorités ne va pas avoir l'effet garanti attendu.
    maitenant je serais curieux de savoir si un truc comme ça peut marcher et dans quelles circonstances....

    edit: il y a des trucs d'échéances en java "temps réel" mais, si je me souviens bien, on ne garantit rien (sauf d'être prévenu si on n'arrive pas à son but dans le temps imparti).

  9. #9
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    essayer de faire du temps réel en java, c'est suicidaire. Rien que la présence du GC empêche de garantir les temps d'exécution

  10. #10
    Membre Expert
    Inscrit en
    Mai 2006
    Messages
    1 364
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 1 364
    Par défaut
    Il y a toujours l'API de Java RTS de sun :
    http://java.sun.com/javase/technolog...time/index.jsp

    Mais bon, c'est sur que java n'est pas le langage le plus adapté pour faire du temps reel... Il ne faut pas oublier que c'est l'objectif de l'application qui devrait orienter le langage utilisé (ainsi que d'autre choses comme la portabilité, la lecture, ...) et pas le choix du langage qui introduit des contraintes.
    Ceci dit, ce serait bien d'expliquer le besoin (devoir scolaire, projet perso?) pour savoir vers quoi il faut s'orienter (re-implementation d'un algo EDT, ...)

    a+

  11. #11
    Expert éminent
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 482
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 482
    Par défaut
    Citation Envoyé par hwoarang Voir le message
    Il y a toujours l'API de Java RTS de sun :
    http://java.sun.com/javase/technolog...time/index.jsp
    Ce n'est qu'une partie du problème, il faut encore avoir l'OS temsp réel et le CPU temps réel

  12. #12
    Membre Expert
    Inscrit en
    Mai 2006
    Messages
    1 364
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 1 364
    Par défaut
    Citation Envoyé par tchize_ Voir le message
    Ce n'est qu'une partie du problème, il faut encore avoir l'OS temsp réel et le CPU temps réel
    Oui. Et aussi, savoir qu'est ce qu'on entend par temps reel. Je me rappelle avoir lu quelqu'un qui cherchait un programme temps reel pour faire de l'affichage de données (pour etre lu par un client)

Discussions similaires

  1. Problème threads java
    Par idjou dans le forum Concurrence et multi-thread
    Réponses: 3
    Dernier message: 08/06/2007, 15h48
  2. [Thread] [java.lang.IllegalThreadStateException] [Start]
    Par moris113 dans le forum AWT/Swing
    Réponses: 2
    Dernier message: 29/05/2007, 15h44
  3. [JNI] Problème dû aux threads Java
    Par seiryujay dans le forum Entrée/Sortie
    Réponses: 6
    Dernier message: 27/11/2006, 13h14
  4. thread java pour impression
    Par ericT dans le forum Concurrence et multi-thread
    Réponses: 2
    Dernier message: 11/07/2006, 15h09
  5. [PROFILER][THREAD][java.prof] outil gratuit/complet?
    Par narmataru dans le forum Général Java
    Réponses: 11
    Dernier message: 16/11/2005, 12h28

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo