Maison >Java >javaDidacticiel >Introduction détaillée à Colleciton en Java
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);//打印控制台 }
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
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);
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!