Quand vous appelez un programme ou un programme de services pour la première fois, le système alloue du stockage pour les variables de programmes globales et pour d'éventuelles variables dans les sous procédures définies par le mot-clé STATIC. Ce stockage est alloué au programme pour la durée
Stockage statique, RPG et Threads
de vie du groupe d’activation. Chaque fois que vous appelez le programme, il utilise le même stockage pour ces variables. C’est alors un stockage statique.
Les deux autres types de stockage sont le stockage automatique et le stockage empilé. Le premier est utilisé pour la plupart des variables locales dans vos sous-procédures ; il est alloué à la procédure quand elle est appelée et désalloué quand elle revient. Le stockage empilé est alloué par %alloc et %realloc et désalloué par l’opcode DEALLOC.
Tous les modules RPG utilisent le stockage statique, même si le module n’a pas de variables globales, et si toutes les sous-procédures ne définissent que le stockage automatique. Le compilateur RPG utilise le stockage statique pour beaucoup de ses variables internes.
Si un job à deux threads actifs dans le même module, les deux peuvent accéder au stockage statique dans le module. C’est une situation potentiellement dangereuse. Soit le fragment de code suivant :
for index = 1 to 3;
arr(index) = arr(index) + 1;
endfor;
Si ces variables sont en stockage statique, et si un seul thread est actif dans le code, les variables progresseront dans la séquence des valeurs de la figure 1 en suivant le flux des instructions (les variables changeantes sont en rouge). À noter qu’une seul variable change à la fois. Si ces variables sont en stockage statique, et si deux threads à la fois sont autorisés à exécuter ce code, les variables pourraient progresser dans une séquence des valeurs.
Le problème n’est pas limité à deux threads exécutant le même code. Un thread peut fort bien exécuter le fragment de code ci-dessus, tandis qu’un autre exécute le code qui a initialisé la matrice en lisant les enregistrements d’un fichier. Vous ne pouvez pas autoriser ce genre d’interaction dans une application thread-safe. Ces variables statiques sont une ressource partagée, dont l’accès par plusieurs threads doit être surveillé de près.
RPG contrôle de deux manières l’accès au stockage statique d’un module. Quand vous spécifiez THREAD(*SERIALIZE), il est impossible pour deux threads d’exécuter le même code en même temps. En fait, il est impossible pour deux threads de s’exécuter dans une procédure du module en même temps. Si le thread T1 est en train d’exécuter la procédure PROC1, et si le thread T2 tente d’appeler la procédure PROC2 dans le même module, le thread T2 ne pourra commencer l’exécution de PROC2 que quand le thread T1 sera revenu et ne sera plus actif dans le module.
Quand vous spécifiez THREAD(*CONCURRENT), chaque thread a sa propre copie du stockage statique du module. Si le thread T2 commence la boucle et met l’index à 1, l’index que le thread T1 utilise, n’est pas affecté. Avec THREAD(*CONCURRENT), le stockage statique n’est pas une ressource partagée, et donc il n’est pas concerné par la sécurité des threads.
Téléchargez cette ressource
Guide de Threat Intelligence contextuelle
Ce guide facilitera l’adoption d’une Threat Intelligence - renseignement sur les cybermenaces, cyberintelligence - adaptée au "contexte", il fournit des indicateurs de performance clés (KPI) pour progresser d' une posture défensive vers une approche centrée sur l’anticipation stratégique
Les articles les plus consultés
- Afficher les icônes cachées dans la barre de notification
- Partager vos images, vidéos, musique et imprimante avec le Groupe résidentiel
- Activer la mise en veille prolongée dans Windows 10
- N° 2 : Il faut supporter des langues multiples dans SharePoint Portal Server
- Chiffrements symétrique vs asymétrique
Les plus consultés sur iTPro.fr
- BlueSecure repense la sensibilisation à la cybersécurité avec des formats immersifs et engageants
- Les agents d’IA fragilisent la sécurité : pour les sécuriser, inutile de repartir de zéro
- Yampa : innovation en IA, souveraineté et sécurité au service des DSI
- Les marchés publics peuvent-ils encore faire émerger des champions numériques français ?
Articles les + lus
Computex 2026 : 5 signaux forts à retenir
La chaîne d’approvisionnement, point de rupture récurent du SI
Microsoft Build 2026 : contre-offensive des modèles maison face à OpenAI et Anthropic
Rhea1 : SiPearl allume le CPU européen le plus ambitieux pour le HPC et l’IA souveraine
Analyse Patch Tuesday Mai 2026
À la une de la chaîne Tech
- Computex 2026 : 5 signaux forts à retenir
- La chaîne d’approvisionnement, point de rupture récurent du SI
- Microsoft Build 2026 : contre-offensive des modèles maison face à OpenAI et Anthropic
- Rhea1 : SiPearl allume le CPU européen le plus ambitieux pour le HPC et l’IA souveraine
- Analyse Patch Tuesday Mai 2026
