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

C Discussion :

Gestion de mémoire et remplacement de pages


Sujet :

C

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    311
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : Canada

    Informations forums :
    Inscription : Mai 2005
    Messages : 311
    Points : 97
    Points
    97
    Par défaut Gestion de mémoire et remplacement de pages
    Salut à tous,

    je dois faire un programme qui fait la gestion de mémoire,
    en lisant des valeurs numériques à partir d'un fichier texte
    et en les plaçant dans les pages mémoires (exemple 3 pages )
    et en utilisant l'algorithme Optimal c'est à dire remplacer les pages qui ne seront pas utilisées durant une longue période

    exemple si le fichier contient une ligne :
    1, 2, 3, 4, 1, 2, 5, 1, 2, 3, 4, 5

    l'algorithme doit m'afficher les états de la mémoire de cette façon
    (je précise quand il s'agit d'un défaut de page)

    1) 1 DefautPage
    2) 1 2 DefautPage
    3) 1 2 3 DefautPage
    4) 1 2 3 4 DefautPage
    5) 1 2 3 4
    6) 1 2 3 4
    7) 1 2 3 5 DefautPage
    8) 1 2 3 5
    9) 1 2 3 5
    10) 1 2 3 5
    11) 4 2 3 5 DefautPage
    11) 4 2 3 5


    Merci de me donner un coup de main

  2. #2
    Expert éminent sénior

    Femme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Juin 2007
    Messages
    5 189
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 5 189
    Points : 17 141
    Points
    17 141
    Par défaut
    *envoie une brochette de doigts par la poste*
    quoi, ce n'est pas ca que tu voulais comme coup de main?


    Bonjour à toi.

    Concrètement, nous n'avons pas de code sous la main, et pas de question.

    Quel est ton problème?
    Mes principes de bases du codeur qui veut pouvoir dormir:
    • Une variable de moins est une source d'erreur en moins.
    • Un pointeur de moins est une montagne d'erreurs en moins.
    • Un copier-coller, ça doit se justifier... Deux, c'est un de trop.
    • jamais signifie "sauf si j'ai passé trois jours à prouver que je peux".
    • La plus sotte des questions est celle qu'on ne pose pas.
    Pour faire des graphes, essayez yEd.
    le ter nel est le titre porté par un de mes personnages de jeu de rôle

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    311
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : Canada

    Informations forums :
    Inscription : Mai 2005
    Messages : 311
    Points : 97
    Points
    97
    Par défaut
    Bah en fait, je ne sais pas comment faire l'algorithme Optimal,
    genre regarder dans les valeurs futurs à rentrer puis décider laquelle qu'on va sollicité le plus loin

    dans le code qui suit, je l'ai fait avec l'algorithme FIFO, premier entré premier à remplacer , dans ce devoir il faut que je fasse avec FIFO, Optimal et LRU


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
     
     
    FILE *fic;
    	int nbPages = atoi(argv[2]);
    	int nbDefautPag = 0;
    	int numLign = 0;
    	int valeur, i, k, t;
    	int cases[nbPages];
    	int trouve;
    	int etat;
     
    	k = 0;
    	for (i=0; i<nbPages; i++)
    	{
    		cases[i]= 0;
    	}
     
    	//Traitement Optimal
    	fic = fopen(argv[1], "r");
    	if (fic != NULL)
    	{
     
    		while ( !feof(fic) ) { //On lit le fichier tant qu'on est pas rendu à la fin
     
    			fscanf(fic, "%d", &valeur);
     
     
    			for (i=0; i<nbPages; i++)
    			{
    				if (cases[i] == valeur){
    					trouve =1;				
    					etat = ' ';
    					break;
    				}
    			}
     
    			//si la valeur n'existe pas dans le tableau alors on l'insère
    			if (trouve == 0){
    				cases[k]= valeur;
    				k= k+1;						
    				nbDefautPag = nbDefautPag +1;
    			}
     
    			//Affichage des résultats
    			numLign = numLign + 1;
    			printf("\n %d)	", numLign);
     
    			for (t=0; t<nbPages; t++)
    			{
    				printf("%d		", cases[t]);
     
    			}
    			printf("%c", etat);			
     
     
     
     
                 }
     
            }

  4. #4
    Expert éminent sénior
    Avatar de Sve@r
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2006
    Messages
    12 690
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Oise (Picardie)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 12 690
    Points : 30 985
    Points
    30 985
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par da_latifa Voir le message
    genre regarder dans les valeurs futures à rentrer puis décider laquelle qu'on va solliciter le plus loin
    Bonjour

    C'est exactement ça. Mais comme tu connais déjà ces valeurs (elles sont dans ton fichier)...

    Citation Envoyé par da_latifa Voir le message
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    		while ( !feof(fic) ) { //On lit le fichier tant qu'on est pas rendu à la fin
    Ca ça ne marche pas (et on t'en a déjà parlé !!!)
    Mon Tutoriel sur la programmation «Python»
    Mon Tutoriel sur la programmation «Shell»
    Sinon il y en a pleins d'autres. N'oubliez pas non plus les différentes faq disponibles sur ce site
    Et on poste ses codes entre balises [code] et [/code]

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    311
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : Canada

    Informations forums :
    Inscription : Mai 2005
    Messages : 311
    Points : 97
    Points
    97
    Par défaut Re
    Merci pour votre réponse,

    En fait oui pour eof je sais, je vais le corriger....
    mais ici c'est pas ça mon problème, c'est la façon de procéder pour voir la valeur adéquate pour le remplacement que j'ai de la difficulté à faire, vous comprenez?
    comment voir et décider quelle valeur va être remplacer

    Merci

Discussions similaires

  1. Gestion de la mémoire de remplacement de QIcon
    Par chrtophe dans le forum Débuter
    Réponses: 2
    Dernier message: 25/11/2013, 08h51
  2. Problème de gestion de mémoire (segfault)
    Par Michaël dans le forum C
    Réponses: 7
    Dernier message: 26/05/2007, 09h30
  3. Réponses: 5
    Dernier message: 27/03/2007, 09h51
  4. Gestion de Mémoire Java
    Par lebulls dans le forum Langage
    Réponses: 5
    Dernier message: 18/07/2006, 10h35
  5. [texte] gestion de l'affichage d'une page
    Par guy2004 dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 8
    Dernier message: 10/07/2005, 18h37

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