SWT et Mult-Threading - Java - Programmation
Marsh Posté le 26-01-2005 à 13:53:45
yo c spi a écrit : Bonjour, |
http://java.sun.com/products/jfc/t [...] eads1.html
Citation : Once a Swing component has been realized, all code that might affect or depend on the state of that component should be executed in the event-dispatching thread. |
Citation : The SwingUtilities class provides two methods to help you run code in the event-dispatching thread: |
Marsh Posté le 26-01-2005 à 14:38:14
nraynaud, c'est les coups de pelle à clous pour avoir affirmé ce qu'il affirme dans sa premiere phrase, non?
(meme si c'est *faisable* c'est pas recommmandé quoi, ou je me trompe ?)
Marsh Posté le 26-01-2005 à 14:42:21
c'est *pas* faisable.
y'a des fonctions qui sont isolées dans DefaultDocument, mais ça ne veut pas dire qu'on peut les utiliser à loisir
dans les JTextComponent depuis n'importe quel thread.
Marsh Posté le 26-01-2005 à 16:07:42
Ce que je voulais dire c'est que c'est complétement transparent pour le programmeur et dans la majorité des cas, ce n'est pas nécessaire de s'en préoccuper.
Marsh Posté le 03-02-2005 à 13:10:26
Exemple:
en swing :
Code :
|
en SWT :
Code :
|
En Swing, on n'est pas obligé de faire appel a invokeAndWait() ou invokeLater() pour mettre à jour le champ du label, alors que l'on est obligé de le faire pour SWT.
Marsh Posté le 03-02-2005 à 14:01:19
yo c spi a écrit : Exemple:
|
c'est complètement interdit ! c'est marqué dans le lien au-dessus !
Marsh Posté le 03-02-2005 à 14:16:41
Le truc vicieux avec ce genre de choses c'est que ça a de bonnes chances de marcher dans la plupart des cas... jusqu'au jour où ça va crasher lamentablement.
D'une manière générale, c'est pareil pour swing et SWt : seul le thread de repartition des evenements doit modifier la gui.
Pour SWT, si tu veux t'affranchir de ce genre de considérations, il y a JFace.
Marsh Posté le 03-02-2005 à 15:11:29
En gros, on devrait toujours utiliser invokeAndWait et invokeLater a chaque appel d'un composant swing si on veut avoir un code copmplétement stable?
Marsh Posté le 03-02-2005 à 15:13:23
exactement, mais uniquement quand tu veux agir sur la gui "de l'exterieur" : les callbacks appelés en réponse à des évenements dus à l'utilisateur s'executent dans le thread de repartition des evenements, donc il n'y a pas de problème.
Marsh Posté le 04-02-2005 à 16:02:37
Ok d'ac, je viens d'apprendre un truc, merci.
Mais revenons en à ma question de départ :
yo c spi a écrit : Je programme les appels aux méthodes comme ceci et je voulais savoir si c'était assez "propre" (ca ne me le semble pas) ou s'il y a une autre méthode de conception plus logique. |
Marsh Posté le 04-02-2005 à 16:08:51
à part utiliser .equals() au lieu de ==, c'est ce que je fais perso.
Marsh Posté le 04-02-2005 à 21:20:13
nraynaud a écrit : à part utiliser .equals() au lieu de ==, c'est ce que je fais perso. |
Ca n'a pas d'importance ici, si 2 Threads sont "equals", c'est que ce sont les memes, donc meme adresse mémoire.
De plus, la méthode equals sur un Thread est celle de la classe Object qui est (il me semble) :
Code :
|
Pour en revenir au sujet, moi je ne trouve pas ca très propre la méthode publique appelant la méthode privée "real...".
edit :
Vu dans API Java a écrit : The equals method for class Object implements the most discriminating possible equivalence relation on objects; that is, for any non-null reference values x and y, this method returns true if and only if x and y refer to the same object (x == y has the value true). |
Marsh Posté le 04-02-2005 à 21:36:59
vla le couplage et la stabilité.
Marsh Posté le 26-01-2005 à 13:41:23
Bonjour,
A la différence de Swing, SWT ne permet pas aux Threads différents de celui qui a créé l'interface graphique (user interface thread) de la modifier. Les actions à effectuer doivent se faire par l'intermédiaire des méthodes Display.syncExec(Runnable) et Display.asyncExec(Runnable).
Ce qui m'amène à me poser quelques questions surtout au niveau de l'architecture des programme (pour programmer propre et intelligement).
J'ai 2 Thread : le user interface et un autre qui bosse derrière mais qui doit modifier par brefs moments l'interface. Ce Thread ne peut éxécuter les méthdes syncExec et asyncExec (car mon appli a une interface swing et une swt, et que la classe du Thread est la meme pour les 2 versions, mais la n'est pas le problème). Ce Thread communique avec une classe (nommons la A) pour effectuer les changements. Cette classe A a été créée par le user inteface Thread et est accédé par les 2.
Je programme les appels aux méthodes comme ceci et je voulais savoir si c'était assez "propre" (ca ne me le semble pas) ou s'il y a une autre méthode de conception plus logique.
---------------
J.C. Farinet