Maison >Java >javaDidacticiel >Explication détaillée des exemples d'utilisation de la liste Java

Explication détaillée des exemples d'utilisation de la liste Java

高洛峰
高洛峰original
2017-01-19 11:12:521210parcourir

|--Liste : Les éléments sont dans l'ordre (vous pouvez les retirer comme vous les enregistrez, l'ordre ne sera pas gâché), et les éléments peuvent être répétés (il peut y avoir un 3 sur l'indice 1, et il peut aussi y avoir un 3 en indice 2) Parce que le système de collecte a un index,
|-- ArrayList : La structure de données sous-jacente utilise une structure de tableau (la longueur du tableau est variable et peut être étendue de 50%) (la la caractéristique est que la requête est rapide, mais les ajouts et les suppressions sont lents) Les threads ne sont pas synchronisés
|-- LinkedList : la structure de données sous-jacente est une structure de liste chaînée (caractérisée par une requête lente et un ajout et une suppression rapides)
|-- Vecteur : la structure de données sous-jacente est une structure de données de tableau et une synchronisation de threads (la longueur du tableau est une extension variable à 100 %) (les requêtes ainsi que les ajouts et les suppressions sont très lents, remplacés par ArrayList)

Liste : méthode unique, toute méthode pouvant faire fonctionner l'indice est unique au système

Ajouter

boolean add(int index, E element)
boolean addAll(index,Collection)
 public static void List_add(){
     ArrayList a1 = new ArrayList();
     a1.add("java");
     a1.add("php");//List集合中的元素可以重复
    a1.add(".net");
     System.out.println("原集合:"+a1);
     a1.add(1, "Flash");
     a1.add(0, "ps");    
     System.out.println(a1);

    ArrayList a2 = new ArrayList();
    a2.add("javascript");
    a2.add("3dMax");
    a2.add("IBM");

    a1.addAll(0, a2);
    System.out.println(a1);
}

Supprimer l'élément à la position spécifiée

 boolean remove(int index)
 public static void List_remove(){
     ArrayList a1 = new ArrayList();
     a1.add("javascript");
     a1.add("php");
     a1.add("flash");
     System.out.println("原集合:"+a1);

     a1.remove(0);
     System.out.println(a1);
}

Modifier l'élément avec l'ensemble d'index spécifié (index int, élément E) Renvoyé C'est l'élément modifié

 public static void List_set() {
     ArrayList a1 = new ArrayList();
     a1.add("javascript");
     a1.add("php");
     a1.add(".net");
     System.out.println("原集合:"+a1);

     a1.set(1, "falsh");
     System.out.println(a1);
}

Vérifier

get(int index)   返回列表中指定位置的元素
subList(int fromIndex, int toIndex)    返回列表中指定的 fromIndex(包括 )和 toIndex(不包括)之间的部分元素。
 public static void List_get() {
     ArrayList a1 = new ArrayList();
     a1.add("java");
     a1.add("php");
     a1.add("flash");

     System.out.println(a1.get(0));//获取指定角标的元素,有了该方法就可以遍历该集合中的所有元素

     System.out.println(a1.subList(1, 3));//获取集合中某一部分的元素,包含头不包含尾
}

Itérateur unique à la collection List : ListIterator (est une sous-interface d'Iterator)

Remarque :
Lors d'une itération, vous ne pouvez pas faire fonctionner les éléments de la collection via les méthodes de l'objet de collection
Parce que ConcurrentModificationException (exception de concurrence) se produira
Ainsi, lorsque vous utilisez l'itérateur, vous ne pouvez utiliser que la méthode itérateur Element
Parce que la méthode Iterator est limitée, elle ne peut juger, supprimer et supprimer des éléments. > Si vous souhaitez d'autres opérations telles que l'ajout, la modification, etc., vous devez utiliser sa sous-interface, ListIterator
L'interface ne peut être obtenue que via la méthode listIterator de la collection List

<.>Vector : L'énumération est une méthode d'extraction unique de Vector, qui est très similaire à l'itérateur (en fait, l'énumération et l'itération sont les mêmes) et a été remplacée par l'itérateur
 public class ListIteratorDemo {
     public static void main(String[] args) {
         ArrayList a1 = new ArrayList();
         a1.add("java01");
         a1.add("java02");
         a1.add("java03");
         a1.add("java04");

         System.out.println("原集合是:"+a1);

      /*在迭代过程中准备添加或者删除元素
      Iterator it = al.iterator();
      while (it.hasNext()){
        Object obj = it.next();

        if (obj.equals("java02"))
        //al.add("java008");//会出现并发异常,因为迭代器正在操作集合,不能再用集合的方法操作集合了
        it.remove();//将java02的引用从集合中删除了
        System.out.println("obj:"+obj);
        }
        */   
    //只有List的listIterator有增,删,改,查这些功能,因为只有List有索引
       ListIterator li = a1.listIterator();
          while (li.hasNext()){
          if(li.next().equals("java02"))
          //li.add("java009");
          li.set("java006");
        }   
    }
}

LinkedList :
 public class VectorDemo {
     public static void main(String[] args) {
         Vector v = new Vector();
         v.add("java01");
         v.add("java02");
         v.add("java03");
         v.add("java04");

         for(Enumeration en = v.elements();en.hasMoreElements();){
            System.out.println(en.nextElement());
        }
    }

}

Méthodes spéciales :

addFirst(); ajouter des éléments en tête addLast(); ajouter des éléments en queue

getFirst (); Récupère les éléments mais ne les supprime pas. eux. S'il n'y a aucun élément dans la collection, NoSuchElementException se produira

removeFirst(); removeLast(); Récupère l'élément mais supprime l'élément. S'il n'y a aucun élément dans la collection, NoSuchElementException se produira

Dans JDK1.6, méthodes alternatives

offerFirst(); offerLast();

peekFirst(); () ; Récupère l'élément, mais l'élément n'est pas supprimé. S'il n'y a aucun élément dans la collection, null sera renvoyé

pollFirst(); pollLast(); L'élément est obtenu, mais l'élément est supprimé. S'il n'y a aucun élément dans la collection, null sera renvoyé

 public class LinkedListDemo {
     public static void main(String[] args) {
         LinkedList link = new LinkedList();
         link.add("java01");
         link.add("java02");
         link.add("java03");
         link.add("java04");

         while(!link.isEmpty()){
            System.out.println((link.removeLast()));
        }
    }
}


Pour des exemples d'utilisation de liste Java plus détaillés et des articles connexes, veuillez prêter attention au site Web PHP chinois !

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn