Maison  >  Article  >  Java  >  Méthodes de collection Java pour implémenter les classes ArrayList et LinkedList

Méthodes de collection Java pour implémenter les classes ArrayList et LinkedList

黄舟
黄舟original
2017-10-20 10:07:512394parcourir

L'éditeur suivant vous proposera un article sur la façon d'implémenter les classes de collection Java ArrayList et LinkedList. L'éditeur le trouve plutôt bon, je vais donc le partager avec vous maintenant et le donner comme référence pour tout le monde. Suivons l'éditeur et jetons un coup d'œil

Liste des méthodes de liste

方法名 功能说明
ArrayList() 构造方法,用于创建一个空的数组列表
add(E e) 将指定的元素添加到此列表的尾部
get(int index) 返回此列表中指定位置上的元素
size() 返回此列表中的元素数
clear() 移除此列表中的所有元素
isEmpty() 如果此列表中没有元素,则返回true
remove(int index) 移除此列表中指定位置上的元素
indextof(Object o) 返回此列表中首次出现的指定元素的索引,或如果此列表不包含元素,则返回-1
toArray 按适当顺序(从第一个到最后一个元素)返回包含此列表中所有元素的数组

Un exemple simple sera utilisé pour illustrer :

Classe d'implémentations ArrayList


package yjlblog;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class Test {
 
 public static void main(String[] args) {
  List list = new ArrayList();//List 是接口,用多态需要指向它的实现类
  list.add("double kill");
  list.add("three kill");
  list.add("four kill");
  list.add("pentakill");
  System.out.println(list); //[double kill, three kill, four kill, pentakill]
        //默认调用的是tostring 方法,但是这个头string方法不是object里面的,可以查帮助文档可知,是继承的collection的一个方法
  System.out.println(list.get(2)); //four kill
  String s = (String)list.get(2);//如果用定义变量的形式来表示的话,需要用到强制类型的转换,因为list。get()方法是object的类里的
  System.out.println(list.isEmpty());
  //false
  //list.clear();
  //System.out.println(list.isEmpty());
  //true
  //System.out.println(list.remove(2));//输出制定索引的 被“删除的元素”
  list.remove(1);//删除索引为“1” 的元素
  System.out.println(list);//[double kill, four kill, pentakill],删除了索引为“1”的元素
  System.out.println(list.indexOf("double kill"));//0 输出所指明字符串的 “索引值”

  System.out.println(list.size());// 3 ,返回数组的长度
  
  Object[] obj = list.toArray();
  System.out.println(obj.length);
  //数组的遍历 for 循环
  for (int i = 0;i < list.size();i++)
  {
   System.out.print(list.get(i)+" ");
   
  }
  System.out.println();
  //使用for each 语句
  for (Object x:list)
  {
   System.out.print(x+" ");
  }
  System.out.println();
  //使用迭代器
  //1.先获得list集合的迭代器
  Iterator iterator = list.iterator();
  //2.通过它的hasNest方法,判断是否遍历完成,用循环实现
  while (iterator.hasNext() == true)
  {
  //3.使用next方法,去除它的下一个元素
   System.out.print(iterator.next()+" ");
   
  }
  System.out.println();
   
  
  
 }

}
//再写上迭代器的说明
//加上arraylist 和 linbkedlist的区别 和代码
//加上后面的几个方法

Classe d'implémentations LinkedList

Une implémentation de liste chaînée de l'interface List, qui implémente toutes les opérations de liste facultatives et autorise tous les éléments (y compris null). En plus d'implémenter l'interface List, la classe LinkedList fournit également une méthode de dénomination unifiée pour obtenir, supprimer et insérer des éléments au début et à la fin de la liste. Ces opérations permettent d'utiliser des tables de listes chaînées comme piles, files d'attente ou deques.

Quelques méthodes de LinkedList

addLast(E e) tr>
package yjlblog;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;

public class Test {
 
 public static void main(String[] args) {
  List list = new LinkedList();//List 是接口,用多态需要指向它的实现类
  list.add("double kill");
  list.add("three kill");
  list.add("four kill");
  list.add("pentakill");
  System.out.println(list); //[double kill, three kill, four kill, pentakill]
  //和ArrayList 的其他方法都是一样的,只是加了一些方法
Nom de la méthode Description de la fonction
方法名 功能说明
addFirst(E e) 将指定元素插入此列表的开头
addLast(E e) 将指定元素添加到此列表的结尾
removeFirst() 移除并返回此列表的第一个元素
removeLast() 移除并返回此列表的最后一个元素
getFirst() 返回此列表中的第一个元素
getLast() 返回此列表中的最后一个元素
addFirst(E e) Insère l'élément spécifié au début de cette liste

Ajoute l'élément spécifié à la fin de cette liste
removeFirst() Supprimer et renvoyer le premier élément de cette liste
removeLast() Supprimer et renvoyer le dernier élément de cette liste
getFirst() Renvoie le premier de cette liste Un élément

getLast() Renvoyer le dernier élément de cette liste

Parcours des collections

Il est également mentionné dans l'exemple ci-dessus, regardez le code ci-dessous

Utiliser la boucle for

Utiliser la boucle for -each

Utiliser l'interface Iterator

Chaque classe de collection fournit une méthode itérateur pour renvoyer un itérateur, via cet itérateur, vous pouvez Pour terminer l'opération de parcours ou de suppression du collection, les étapes pour utiliser l'itérateur sont les suivantes :

****

1 Obtenez l'itérateur de la collection via la méthode Iterator

2. la méthode hasNext pour déterminer s'il existe l'élément suivant
//数组的遍历 for 循环
for (int i = 0;i < list.size();i++)
{
 System.out.print(list.get(i)+" ");
 
}
System.out.println();
//使用for each 语句
for (Object x:list)
{
 System.out.print(x+" ");
}
System.out.println();
//使用迭代器
//1.先获得list集合的迭代器
Iterator iterator = list.iterator();
//2.通过它的hasNest方法,判断是否遍历完成,用循环实现
while (iterator.hasNext() == true)
{
//3.使用next方法,去除它的下一个元素
 System.out.print(iterator.next()+" ");
 
}
System.out.println();
3 Utilisez la méthode next pour supprimer son élément suivant .

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