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 :

ArrayList en Java


Sujet :

Collection et Stream Java

  1. #1
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Novembre 2012
    Messages
    181
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Novembre 2012
    Messages : 181
    Points : 64
    Points
    64
    Par défaut ArrayList en Java
    Bonsoir tout le monde,,

    Je voudrais savoir à propos la déclaration mentionnée ci-après, de quelle structure de données s'agit-elle ? J'ai une confusion entre une liste chaînée en java et un tableau de chaîne de caractère.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
     ArrayList<String> ABC = new ArrayList<String>();

    Merci.

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    Salut,

    Il s'agit tout d'abord d'une List, donc une Collection qui permet l'accès direct aux éléments par leur index. De plus, il s'agit d'une ArrayList, une liste dont le stockage des éléments est effectués dans un tableau (en interne).
    L'expression "ça marche pas" ne veut rien dire. Indiquez l'erreur, et/ou les comportements attendus et obtenus, et donnez un Exemple Complet Minimal qui permet de reproduire le problème.
    La plupart des réponses à vos questions sont déjà dans les FAQs ou les Tutoriels, ou peut-être dans une autre discussion : utilisez la recherche interne.
    Des questions sur Java : consultez le Forum Java. Des questions sur l'EDI Eclipse ou la plateforme Eclipse RCP : consultez le Forum Eclipse.
    Une question correctement posée et rédigée et vous aurez plus de chances de réponses adaptées et rapides.
    N'oubliez pas de mettre vos extraits de code entre balises CODE (Voir Mode d'emploi de l'éditeur de messages).
    Nouveau sur le forum ? Consultez Les Règles du Club.

  3. #3
    Membre confirmé
    Avatar de Jacques Beauregard
    Homme Profil pro
    Développeur Java
    Inscrit en
    Mai 2015
    Messages
    231
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2015
    Messages : 231
    Points : 595
    Points
    595
    Par défaut
    Salut,

    Pour plus d'informations sur les collections :

    http://java.developpez.com/faq/java/...es-collections

    cordialement.
    Il ne faut jamais prendre les gens pour des cons, mais il ne faut pas oublier qu'ils le sont...

    Le guide du débutant pour apprendre à programmer en Java - N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java

  4. #4
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Novembre 2012
    Messages
    181
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Novembre 2012
    Messages : 181
    Points : 64
    Points
    64
    Par défaut
    Merci pour vos réponses.
    Donc si je passe à écrire un algorithme utilisant cette structure, je la définisse comme un tableau de chaîne ou bien une liste chaînée ?
    Je pense qu'au niveau Java, il y a pas la notion de liste chaînée plutôt c'est la notion de collections et list, car même au niveau de codage mon programme utilise des fonctions prédéfinies comme :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    static void occurence(ArrayList<String> list) {
            Set<String> unique = new HashSet<String>(list);
            for (String key : unique) {
                System.out.println(key + ": " + Collections.frequency(list, key));
     
            }
    Cordialement
    Merci

  5. #5
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Tout ce qui est liste chainée en java (dans les apis de base) est clairement mentionné comme tel: LinkedList, LinkedHashMap, LinkedHashSet, etc. Idem pour ce qui est arbre. Maintenant, en tant que développeur, tu t'en fous de savoir que c'est une LinkedList, une ArrayList, un Vector ou autre. Ce qui compte, c'est que c'est une List et qu'elle a des temps garantis pour ses méthodes en fonction de son Type. Une LinkedList est idéal pour un ajout en fin de list, mais catastrophique pour un accès random.

  6. #6
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Novembre 2012
    Messages
    181
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Novembre 2012
    Messages : 181
    Points : 64
    Points
    64
    Par défaut
    Bonsoir ,

    Oui en fait j'utilise déjà cette structure de donnée au niveau de mon programme, et ça donne de bon résultat lors de l’exécution. Juste je voudrais savoir l'équivalent de ArrayList au niveau algorithmique. De même je voudrais savoir aussi la différence entre un tableau de chaîne et une liste de chaîne pour le Java. Car les indices de l'indexation (prédécesseur, successeur, pointeur .. ) ne figure pas dans mon programme ... Voila la confusion


    Merci
    Cordialement

  7. #7
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Une arraylist est en gros un tableau dynamique. La différence avec un tableau est qu'un tableau a une taille fixe et des méthodes en moins. Et les pointeurs ca n'existe pas en java et le compilateur n'as pas de préprocesseur. J'ignore ce qu'est ce que appele les indices d'indexation.

  8. #8
    Membre du Club
    Femme Profil pro
    Étudiant
    Inscrit en
    Novembre 2012
    Messages
    181
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : Tunisie

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Matériel informatique

    Informations forums :
    Inscription : Novembre 2012
    Messages : 181
    Points : 64
    Points
    64
    Par défaut
    Bonjour,

    Donc d'après ce qui est dit : la structure collection propose une série d'interfaces pour gérer efficacement les données. Parmi ces interfaces, nous trouvons les listes.

    Une liste est une suite ordonnée d'éléments. Un élément peut être ajouté à plusieurs endroits dans une même liste.

    La classe java.util.ArrayList utilise un tableau en interne pour ranger les données. Un ArrayList fournit un accès aux éléments par leur indice très performant et est optimisé pour des opérations d'ajout/suppression d'éléments en fin de liste.

    Cordialement

  9. #9
    Expert éminent sénior
    Avatar de tchize_
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Avril 2007
    Messages
    25 481
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Belgique

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2007
    Messages : 25 481
    Points : 48 806
    Points
    48 806
    Par défaut
    Oui, concernant les temps d'accès c'est documenté ici
    https://docs.oracle.com/javase/7/doc...ArrayList.html

    • size, isEmpty, get, set, iterator et listIterator sont en temps constant.
    • add est est en temps constant amorti
    • Les autres méthods sont en temps linéaire
    • Le facteur constant est faible comparé à une LinkedList

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Jtable et ArrayList en Java
    Par Aleatoire88 dans le forum Composants
    Réponses: 2
    Dernier message: 05/02/2013, 13h55
  2. Convertir java.util.ArrayList en java.sql.Array
    Par archer dans le forum JDBC
    Réponses: 3
    Dernier message: 13/07/2010, 10h53
  3. Afficher contenu de Arraylist dans java
    Par aminos88 dans le forum Collection et Stream
    Réponses: 8
    Dernier message: 06/06/2009, 09h35
  4. Problème d'ArrayList en Java
    Par pymouse dans le forum Collection et Stream
    Réponses: 3
    Dernier message: 28/04/2009, 16h42
  5. explication ArrayList en java
    Par drexlbob dans le forum Collection et Stream
    Réponses: 1
    Dernier message: 02/02/2008, 00h54

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