Non usage de la mémoire virtuelle

Messages postés
29
Date d'inscription
jeudi 8 octobre 2009
Statut
Membre
Dernière intervention
6 octobre 2019
- - Dernière réponse : [Dal]
Messages postés
5253
Date d'inscription
mercredi 15 septembre 2004
Statut
Contributeur
Dernière intervention
21 octobre 2019
- 28 sept. 2019 à 16:09
Bonjour,

D'une manière générale, est-il possible dans l'écriture d'une application d'empêcher qu'elle utilise la mémoire virtuelle de manière à en préserver la performance?

Merci.
Afficher la suite 

4 réponses

Messages postés
5253
Date d'inscription
mercredi 15 septembre 2004
Statut
Contributeur
Dernière intervention
21 octobre 2019
806
0
Merci
Salut lucjs,

Les API de ton système d'exploitation peuvent te permettre d'inspecter l'état de la mémoire de la machine, ce qui peut permettre à ton application de décider de sa stratégie d'usage de la mémoire.

Par exemple, sous Windows, l'API Win32 te permet d'utiliser la fonction
GlobalMemoryStatusEx()
, pour obtenir des informations sur la quantité de mémoire physique et son occupation, la quantité de mémoire virtuelle et son occupation (et la consommation d'espace dans le fichier de swap pagefile.sys), permettant d'obtenir des informations à un moment T sur les disponibilités mémoire de la machine pour ton application.

https://docs.microsoft.com/fr-fr/windows/win32/api/sysinfoapi/nf-sysinfoapi-globalmemorystatusex

Cette documentation comprend aussi un exemple de code.

Il y a aussi
GetPerformanceInfo()
qui permet d'obtenir des informations additionnelles au delà des ressources mémoire disponibles à ton application.

https://docs.microsoft.com/fr-fr/windows/win32/api/psapi/nf-psapi-getperformanceinfo


Dal
[Dal]
Messages postés
5253
Date d'inscription
mercredi 15 septembre 2004
Statut
Contributeur
Dernière intervention
21 octobre 2019
806 -
Une fois que tu as ce type d'informations, tu peux aussi te servir des "job objects" de l'API Windows.

Tu crées un "job object" à partir d'un programme et tu définis à partir de celui-ci les limites de mémoire (et d'autres types de limites) qui s'imposeront aux processus auxquels tu rattaches le "job object" avec
SetInformationJobObject()
.


https://docs.microsoft.com/fr-fr/windows/win32/api/jobapi2/nf-jobapi2-setinformationjobobject

Cela te permet de déléguer au système d'exploitation la gestion des limites que tu fixes.

Tu as un article synthétisant l'information sur la question, avec une partie parlant aussi de la possibilité de gérer des notifications lorsque les limites imposées sont excédées.

https://docs.microsoft.com/fr-fr/windows/win32/procthread/job-objects#job-limits-and-notifications
Commenter la réponse de [Dal]
Messages postés
29
Date d'inscription
jeudi 8 octobre 2009
Statut
Membre
Dernière intervention
6 octobre 2019
1
0
Merci
Merci beaucoup pour l'information; je ne programme pas moi-même mais une application que j'utilise (Albelli, album photos) donne un message "out of memory" (message de l'application, pas du système d'exploitation); ils prétendent que ma mémoire de travail (4 GB, ils demandent minimum 2GB) est insuffisante, je pense moi que c'est leur programme qui gère mal la mémoire virtuelle.
J'ai essayé de "saturer" le PC en lançant un tas d'applications et en ouvrant un tas de fenêtres, il finit par ramer, logique, mais ne donne aucune erreur.
Au moment du "out of memory", la mémoire de travail est occupée vers 80% (dont +-1Gb pour albelli) mais je dispose largement de mémoire virtuelle.
Qu'en pensez-vous?
Commenter la réponse de lucjs
Messages postés
14570
Date d'inscription
vendredi 14 mars 2003
Statut
Modérateur
Dernière intervention
21 octobre 2019
179
0
Merci
Le mémoire virtuelle est gérée par l'OS, les applications ne sont pas sensées la manipuler, c''est transparent pour elles.
Rapproches-toi plus du fournisseur alors, car ici on s'occupe de programmation pas d'assistance informatique.
lucjs
Messages postés
29
Date d'inscription
jeudi 8 octobre 2009
Statut
Membre
Dernière intervention
6 octobre 2019
1 -
Merci, mais dans ce cas, il s'agit bien de programmation, mais pas la mienne ! La seule manière de savoir si le fournisseur me raconte des bobards (ce que je pense) est de savoir s'il est possible d'empêcher le travail normal de swapping par programmation: logiquement, le PC doit ralentir et même quasiment se bloquer si l'on a une charge d'échange extrême, mais qu'une application donne un "out of memory" (alors que c'est censé être transparent, comme vous le dites) me semble un bug...
Commenter la réponse de NHenry
Messages postés
5253
Date d'inscription
mercredi 15 septembre 2004
Statut
Contributeur
Dernière intervention
21 octobre 2019
806
0
Merci
Salut lucjs,

Plutôt que de lancer des applications dans tous les sens pour charger la mémoire de ta machine et tester les conditions dans lesquelles ton logiciel renvoie une erreur d'allocation de mémoire, tu peux utiliser les "job objects" de l'API Windows pour que Windows limite la quantité de mémoire que ton logiciel peut allouer.

Je t'ai expliqué comment le faire si tu sais programmer.

Si tu ne sais pas programmer, tu as un outil de ligne de commande open source sous licence MIT (lbre et gratuit) qui s'appelle "process-governor" et qui permet de d'attacher des "job objects" à des processus.

https://github.com/lowleveldesign/process-governor (sources en C# et instructions d'usage)
https://lowleveldesign.org/2013/11/21/set-process-memory-limit-with-process-governor/ (site du concepteur avec instructions et explications)
https://github.com/lowleveldesign/process-governor/releases (binaire exécutable dans le .zip)

En réduisant la quantité de mémoire disponible au programme que tu veux tester, tu rencontreras plus rapidement l'erreur en question, et cela pourra te faciliter la recherche des conditions à réunir pour que l'erreur d'allocation mémoire se manifeste. Lorsque tu sauras reproduire le problème, tu pourras fournir à l'éditeur du logiciel des informations utiles au diagnostic d'une éventuelle erreur (si ce que tu vois est effectivement un bogue).

Sinon, si tu veux juste pouvoir maximiser tes chances de ne pas rencontrer cette erreur, je te conseille au contraire de ne pas utiliser "process-governor", de fermer toutes autres applications et services non utilisés et consommateurs de mémoire, et d'augmenter la taille de ton fichier de swap pagefile.sys.

Dal
Commenter la réponse de [Dal]