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

Collection et Stream Java Discussion :

liste taille fixe


Sujet :

Collection et Stream Java

  1. #1
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 6
    Points : 3
    Points
    3
    Par défaut liste taille fixe
    bonjour,

    je cherche à gérer une liste simple de taille fixe de style "identifiant-valeur"
    les opérations seront uniquement insertion d'une paire identifiant-valeur et récupération d'une valeur depuis son identifiant.
    je veux qu'en cas de liste complète, la plus ancienne paie soit retirée automatiquement avant l'ajout.
    y a t-il un moment existant et performant de faire cela ? (sachant que je ne stocke pas l'heure d'insertion, peut-être devrais-je le faire ?)

    merci pour vos idées.

  2. #2
    Membre averti
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    230
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 230
    Points : 310
    Points
    310
    Par défaut
    Bonjour,

    Tu dois pouvoir utiliser cela :
    http://javasearch.developpez.com/j2s...edHashMap.html

    en surchargeant la méthode removeEldestEntry(Map.Entry) pour qu'elle supprime bien l'entrée la plus ancienne lorsque la taille de ta map est atteinte.

  3. #3
    Membre averti
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    338
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Mars 2008
    Messages : 338
    Points : 402
    Points
    402
    Par défaut
    Si t'utilise java 5.0 regarde ArrayBlockingQueue

  4. #4
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 6
    Points : 3
    Points
    3
    Par défaut
    sauf que la liste est vide au départ (cela dit je peux contourner ce problème).
    et ce type de liste n'est-il pas peu performant (je ferai beaucoup d'accès et insertion)?

    j'avais pensé à une ArrayList au départ (avec la méthode removeRange mais cela implique que je dois contrôler moi-même ce remove ), et utiliser le indexOf(objetc) pour savoir à quel index se trouve mon identifiant lors de chaque accès, ce qui est lourd)

  5. #5
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Salut,


    Que veux-tu précisément. Tu parles de liste mais ta description fait plutôt penser à une Map !

    Bref : détailles un peu mieux ton besoin (éventuellement avec des exemples de données, et de la manière dont tu y accèdes).

    a++

  6. #6
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 6
    Points : 3
    Points
    3
    Par défaut
    oui, j'employais le terme de liste ça porte à confusion car ça ressemble plus à une map.

    disons que j'ai des paires identifiants-valeurs à stocker de façon temporaire.
    des nouvelles paires apparaissent continuellement donc je fais continuellement des insertions en vérifiant au préalable que l'identifiant ne s'y trouve pas déjà.
    si je ne fais rien, ma liste/map/tableau ou autre va grossir à l'infini.
    Or la durée de vie d'un identifiant est assez courte : j'y accède souvent dans un laps de temps qui suit son insertion mais pas la suite il ne sera pas utilisé, d'où l'idée de supprimer les n plus anciennes insertions lors des n nouvelles insertions.
    Est-ce plus clair ?
    Je recherche donc un modèle de stockage de taille fixe et performant pour ce besoin, et se vidant automatiquement aussi.

  7. #7
    Expert éminent sénior
    Avatar de adiGuba
    Homme Profil pro
    Développeur Java/Web
    Inscrit en
    Avril 2002
    Messages
    13 938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Java/Web
    Secteur : Transports

    Informations forums :
    Inscription : Avril 2002
    Messages : 13 938
    Points : 23 190
    Points
    23 190
    Billets dans le blog
    1
    Par défaut
    Dans ce cas la LRUMap des Jakarta Commons Collections me semble correspondre à ton besoin...

    a++

  8. #8
    Candidat au Club
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    6
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2007
    Messages : 6
    Points : 3
    Points
    3
    Par défaut
    j'avais été faire un tour sur ces Collections en passant au travers.
    Effectivement c'est pas mal du tout.
    Merci !

Discussions similaires

  1. scroll (positionnement) sur une liste dans DIV de taille fixe
    Par Heretic dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 11/05/2010, 16h26
  2. liste deroulante a taille fixe.
    Par nintendoplayer dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 27/11/2007, 17h20
  3. Taille fixe div css
    Par Jiraiya42 dans le forum Mise en page CSS
    Réponses: 1
    Dernier message: 26/04/2006, 20h30
  4. SQL 2000 - Liste + taille des tables et index
    Par Fox dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 12/03/2004, 15h59

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