Maison >Java >javaDidacticiel >Introduction détaillée à Colleciton en Java

Introduction détaillée à Colleciton en Java

PHP中文网
PHP中文网original
2017-06-20 16:33:541296parcourir

Aperçu :

1. Définition de la collection : hérite d'Iterable, possède des fonctions génériques et constitue l'interface parent supérieure du système de collection Collection.

2, Méthodes de collecte : add, addAll ; clear, isEmpty, size ; toArray (surchargé) ; contient, containAll ; deleteAll, retentionAll ;

Tout d'abord, regardons la définition de Collection

<span style="color: #cc7832">public interface Collection<<span style="color: #507874">E> <span style="color: #cc7832">extends Iterable<<span style="color: #507874">E><br><span style="color: #000000">从定义中我们可以看出Collection是一个带<span style="color: #ff0000">泛型的接口</span>。<br>实现了Iterable接口,也就是说可以使用<span style="color: #ff0000">迭代</span>器。<br>以上两点很重要,其下所有子类均有这两个属性。<br>还有一点大家需要注意Collection集合并<span style="color: #ff0000">没有定义查找</span>的方法。<br><br></span></span></span>
Deuxièmement, regardons Encore une fois, regardez les propres méthodes de Colleciton (à l'exclusion des méthodes héritées).

1. Concernant add et addAll.

Les deux ajoutent des éléments à la collection (leurs sous-classes respectives l'implémenteront spécifiquement). Le premier consiste à ajouter un seul élément, et le second consiste à ajouter une collection de sous-classe qui implémente Collection.

Par exemple (j'ai délibérément utilisé différentes sous-classes Collection dans l'exemple) :

<br>
    @Testpublic void testAdd(){
        Collection<String> collection = new LinkedList<>();//添加一个对象collection.add("person1");
        collection.add("person2");

        List<String> list = new ArrayList<>();
        list.add("person3");
        Set<String> set = new HashSet<>();
        set.add("person4");//添加一个Collection集合。        collection.addAll(list);
        collection.addAll(set);

        collection.forEach(System.out::println);//打印控制台
    }
2, effacer , estVide, taille.

Ces méthodes sont relativement simples et grossières, donc je les ai rassemblées, et je ne montrerai pas le code d'ailleurs. clear efface tous les éléments de la collection.

isEmpty détermine s'il y a des éléments dans la collection et renvoie true lorsqu'elle est vide.

size obtient le nombre d'éléments dans l'ensemble.

3. Concernant la conversion d'une collection en un tableau en Array.

Méthode ToArray surchargée, on n'a pas de paramètres et un nombre doit être passé dans un tableau existant. Parlons d'abord de Object[] toArray() sans paramètres. Il renvoie un tableau d'objets, voici donc le problème.

Si vous avez besoin de

String[] objects = (String[]) collection.toArray();

ce faisant, il lancera une

ClassCastException

exception. Alors vous savez peut-être ce que fait le T[] toArray(T[] a) avec les paramètres, voir ci-dessous. Le code suivant imprime les résultats suivants, ce qui signifie que les objets du tableau seront renvoyés dans tous les cas.

Lorsque la longueur du tableau transmis est inférieure à la taille de la collection, un nouveau tableau sera renvoyé séparément et le tableau transmis ne sera pas rempli de données.

Lorsque le tableau transmis est égal ou supérieur à la taille combinée, le tableau entrant est rempli et le tableau est renvoyé.

Remarque : Nous devrions donc généralement utiliser la méthode avec des paramètres dans le deuxième cas

---Imprimer le cas où le tableau donné est plus petit que l'ensemble-----

strings: [null, null]

returnStrings: [escore, wym, cl]

strings==returnStrings: false

---Imprimer le cas où le tableau donné est égal à l'ensemble---- -<br>strings : [escore, wym, cl]<br>returnStrings : [escore, wym, cl]<br>strings==returnStrings : true<br>---Imprime le cas où le tableau donné est plus grand que l'ensemble--- --<br>strings : [escore, wym, cl, null, null]<br>returnStrings : [escore, wym, cl, null, null]<br>strings==returnStrings : true<br><br><br><br>

        Collection<String> collection = new LinkedList<>();
        collection.add("escore");
        collection.add("wym");
        collection.add("cl");       // String[] objects = (String[]) collection.toArray(); //会抛出ClassCastException异常Object[] objects = collection.toArray();//System.out.println(Arrays.toString(objects));String[] strings = new String[2];
        String[] returnStrings = collection.toArray(strings);
        System.out.println("---打印给定的数组小于集合的情况-----");
        System.out.println("strings: "+ Arrays.toString(strings));
        System.out.println("returnStrings: " + Arrays.toString(returnStrings));
        System.out.println(strings == returnStrings);

        String[] strings2 = new String[collection.size()];
        String[] returnStrings2 = collection.toArray(strings2);
        System.out.println("---打印给定的数组等于集合的情况-----");
        System.out.println("strings: "+ Arrays.toString(strings2));
        System.out.println("returnStrings: " + Arrays.toString(returnStrings2));
        System.out.println(strings2 == returnStrings2);

        String[] strings3 = new String[5];
        String[] returnStrings3 = collection.toArray(strings3);
        System.out.println("---打印给定的数组大于集合的情况-----");
        System.out.println("strings: "+ Arrays.toString(strings3));
        System.out.println("returnStrings: " + Arrays.toString(returnStrings3));
        System.out.println(strings3 == returnStrings3);
4

Itérateur

<

E> Concernant la méthode de retour d'un itérateur, nous n'en discuterons pas ici Veuillez vous référer à l'excuse de contenu d'Iterator.

5, contient, contientTout ; supprimer, supprimerTout, conserverTout

contient et contientTout sont respectivement utilisés pour déterminer s'il contient une allicine , si elle contient une collection Collection.

remove, removeAll et retentionAll suppriment respectivement un élément de la collection, suppriment les éléments égaux à la collection Collection et conservent les éléments égaux aux éléments de la collection Collection. Pourquoi les mettre ensemble ?

La méthode equals est impliquée ici ;

C'est-à-dire, comment contain détermine s'il est inclus ? Cette méthode comparera la méthode equals de l'objet entrant avec les éléments de la collection ? un par un sont égaux. La méthode containAll placera chaque élément pour appeler la méthode contain.

De même, Why Remove sait quel élément doit être supprimé et appellera également la méthode Equals pour le comparer un par un avec les éléments de la collection. RemoveAll et containAll feront en sorte que les éléments de collection entrants appellent la méthode Remove un par un, sauf que le premier supprime les mêmes et le second conserve les mêmes.

(Je partagerai tout sur les collections Java dans la catégorie "Java Basic Collection Framework")

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en 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