Re: Question sur les tasks

Liste des GroupesRevenir à fcl ada 
Sujet : Re: Question sur les tasks
De : 314 (at) *nospam* drpi.fr (DrPi)
Groupes : fr.comp.lang.ada
Date : 17. Oct 2023, 22:06:37
Autres entêtes
Organisation : <https://pasdenom.info/news.html>
Message-ID : <ugmt10$jj2$1@rasp.pasdenom.info>
References : 1
User-Agent : Mozilla Thunderbird
Salut Stéphane,
Le 17/10/2023 à 17:57, Stéphane Rivière a écrit :
Bonjour à toutes et tous,
 Msg.Std ou Sql.Ping ne sont pas réentrants mais comme c'est de l'affichage de log ou de la pure lecture de DB, je ne m'en fait pas pour l'instant...
 L'appel à C balaye la table des DB ouvertes et envoie un "SELECT 1" bidon à toutes les DB qui le nécessitent (donc pas les SQLite par exemple).
 Mais au démarrage de l'applic, pour que la line B affiche le message de log :
 TestGui.SQL_Ping > Armed for 3600s cycles
 Il faut que je mette une ligne A avec un appel à delay...
 J'aimerai bien comprendre le truc (et baisser mon ignorance).
  ---------------------------------------
    task SQL_Ping;
     task body SQL_Ping is
       Delay_Value : Duration := 3600.0;  -- Wait 1 hour between pings
    begin
A      delay 0.1; --  Mandatory to displaying the message below
B      Msg.Std ("TestGui.SQL_Ping > Armed for " &
                Trim_Left (Field_By_Index (From_Latin_1 (Duration'Image (Delay_Value)), 1, ".")) & "s cycles");
       while True loop
          delay Delay_Value;
          Msg.Dbg ("TestGui.SQL_Ping > Sent");
C        Sql.Ping;
       end loop;
    end SQL_Ping;
 ---------------------------------------
 
Je ne vois pas de problème lié au tasking de Ada.
Par contre, je vois un problème de tasking au sens général (indépendamment du langage).
Tu dis que la procédure Msg.Std n'est pas réentrante mais que ce n'est pas un problème. Or Msg.Std est appelée à partir de la tâche SQL_Ping et sûrement à partir d'autres tâches comme la tâche principale. A partir de là, il y a un risque de dysfonctionnement.
Par exemple, si Msg.Std est appelée par la tâche principale puis, avant qu'elle ne se termine, est également appelée par la tâche SQL_Ping, il y a problème puisque la fonction n'est pas réentrante.
Le fait d'ajouter un délai au début de la tâche SQL_Ping permet à la fonction Msg.Std de se terminer dans la tâche principale avant d'être appelée dans SQL_Ping. Et tout semble fonctionner parfaitement. Mais ce n'est qu'une illusion. Il est fort probable que dans d'autres conditions de fonctionnement (charge processeur différente, code modifié...), le délai doive être modifié.
Une fonction/procédure appelée à partir de plusieurs tâches DOIT être conçue pour ça (protection avec un mutex, utilisation un objet protégé...).
Nicolas

Date Sujet#  Auteur
17 Oct 23 * Question sur les tasks20Stéphane Rivière
17 Oct 23 +* Re: Question sur les tasks7Pascal Obry
18 Oct 23 i`* Re: Question sur les tasks6Stéphane Rivière
7 Dec 23 i `* Re: Question sur les tasks5Pascal Obry
8 Dec 23 i  `* Re: Question sur les tasks4pehache
8 Dec 23 i   `* Re: Question sur les tasks3Pascal Obry
8 Dec 23 i    `* Re: Question sur les tasks2pehache
8 Dec 23 i     `- Re: Question sur les tasks1Pascal Obry
17 Oct 23 +* Re: Question sur les tasks10DrPi
18 Oct 23 i`* Re: Question sur les tasks9Stéphane Rivière
18 Oct 23 i `* Re: Question sur les tasks8DrPi
19 Oct 23 i  `* Re: Question sur les tasks7Stéphane Rivière
19 Oct 23 i   `* Re: Question sur les tasks6DrPi
19 Oct 23 i    +* Re: Question sur les tasks4J-P. Rosen
20 Oct 23 i    i`* Re: Question sur les tasks3Stéphane Rivière
20 Oct 23 i    i +- Re: Question sur les tasks1J-P. Rosen
20 Oct 23 i    i `- Re: Question sur les tasks1J-P. Rosen
20 Oct 23 i    `- Re: Question sur les tasks1Stéphane Rivière
18 Oct 23 `* Re: Question sur les tasks2Blady
19 Oct 23  `- Re: Question sur les tasks1Stéphane Rivière

Haut de la page

Les messages affichés proviennent d'usenet.

NewsPortal