1、List是一个接口,不能实例化,需要实例化一个ArrayList或者LinkedList
List myList = new ArrayList();
2、List中可以添加任何对象,包括自己定义的新的类。 

  • class Person{
    .....
    }
    上面定义了一个Person类,下面看好如何使用List
    Person p1=new Person();
    Person p2=new Person();
    List myList=new ArrayList();
    myList.add(p1);
    myList.add(p2);//这里是将对象加入到list中
    for(int i=0;i<2;i++){
    Person p=(Person)myList.get(i);//注意,这里一定要强制类型转换,因为List中取出的对象都是Object类型的,希望对你有所帮助 } 3、使用myList.add(任何对象);就可以进行添加了。
    4、取值的时候myList.get(索引);取出来的值都是Object,使用时需要类型转换。
    5、可用Iterator迭代器对List中的元素进行迭代操作。
    List 集合中的对象按照一定的顺序排放,里面的内容可以重复。
    
    List常用方法:
    List<E>([]内的内容可省略),与数组类似:
    实例化:List[<数据类型>] list = new ArrayList[<数据类型>]();
    1、获得集合内元素个数:list.size();
    2、添加元素:
    默认添加:list.add(e);
    指定下标添加(添加后下标后的元素向后挪一位):list.add(index,e);
    3、删除元素:
    返回是否删除:list.remove(e);
    直接删除指定下标的元素(只删除找到的第一个相符合的元素):list.remove(index);
    4、替换元素(替换掉指定下标的元素):list.set(index,e);
    5、取出元素:list.get(index);
    6、清空集合:list.clear();
    7、判断集合中是否存在某个元素(存在返回true,不存在返回false):list.contains(e);
    8、对比两个集合中的所有元素:
    两个对象一定相等:list.equals(list2);
    两个对象不一定相等:list.hashCode() == list2.hashCode();
    (两个相等对象的equals方法一定为true, 但两个hashcode相等的对象不一定是相等的对象。)
    9、获得元素下标:
    元素存在则返回找到的第一个元素的下标,不存在则返回-1:list.indexOf(e);
    元素存在则返回找到的最后一个元素的下标,不存在则返回-1:list.lastIndexOf(e);
    10、判断集合是否为空(空则返回true,非空则返回false):list.isEmpty();
    11、返回Iterator集合对象:list.iterator();
    12、将集合转换为字符串:list.toString();
    13、截取集合(从fromIndex开始在toIndex前结束,[fromIndex,toIndex)):list.subList(fromIndex,toIndex);
    14、将集合转换为数组:
    默认类型:list.toArray();
    指定类型(objects为指定类型的数组对象,并将转换好的数组赋值给objects数组):list.toArray(objects);
    List接口实现的类:ArrayList(实现动态数组), Vector(实现动态数组) ,LinkedList(实现链表), Stack(实现堆栈)
    1.java.util.ArrayList类实现一个可增长的动态数组,平时用的比较多的就是add()方法,其它方法
    请参考API帮助文档。使用该方法向集合内添加对象,并且这些对象是按照一定的顺序排列
    的,它内部原理是数组实现的,因此处理数据量较大时,不建议使用。
    public class TestArrayList {
    
    public static void main(String[] args) {
    //声明List 并实例化为ArrayList
    List al = new ArrayList();
    //使用add()方法添加元素
    al.add("a");
    al.add("b");
    al.add("c");
    al.add("d");
    //使用Iterator迭代器遍历出集合的元素并打印
    for(Iterator i = al.iterator();i.hasNext(); ){
    String str = (String) i.next();
    System.out.println(str);
    }
    } }
    2.java.util.Vector(向量)类 与ArrayList类似的也是实现一个动态的数组,该向量可以随意的增长以存放更多的对象
    
    public class TestArrayList {
    
    public static void main(String[] args) {
    //声明List 并实例化为Vector
    List al = new Vector();
    //使用add()方法添加对象
    al.add("a");
    al.add("b");
    al.add("c");
    al.add("d");
    //使用Iterator迭代器遍历出集合的对象并打印
    for(Iterator i = al.iterator();i.hasNext(); ){
    String str = (String) i.next();
    System.out.println(str);
    }
    } }
    3.java.util.LinkedList类实现了链表,可初始化化为空或者已存在的集合,通常使用以下方法
    add();向链表末尾添加对象。
    addFirst()在链表开头添加对象。
    addLast()在链表末尾添加对象。
    getFirst()得到链表开头的对象。
    getLast()得到链表末尾的对象。
    注意该类提供了随机访问列表中的元素的方法,但是底层依然必须遍历去查找随机访问的对象,因此性能依然有限. public static void main(String[] args) {
    //声明LinkedList并实例化
    LinkedList al = new LinkedList();
    //使用add()方法添加元素
    al.add("a");
    al.add("b");
    al.add("c");
    al.add("d");
    //使用Iterator迭代器遍历出集合的元素并打印
    for(Iterator i = al.iterator();i.hasNext(); ){
    String str = (String) i.next();
    System.out.println(str);
    }
    System.out.println("_____");
    //向链表头和尾分别添加x和z
    al.addFirst("z");
    al.addLast("x");
    //遍历查看添加后的结果
    for(Iterator i = al.iterator();i.hasNext(); ){
    String str = (String) i.next();
    System.out.println(str);
    } } 4.java.util.Stack类实现了堆栈数据结构,即按照先进后出的原则存放数据。创建时只能为空。
    使用push()方法进行添加对象
    public static void main(String[] args) {
    //声明Stack并实例化
    Stack al = new Stack();
    //使用push()方法添加元素
    al.push("a");
    al.push("b");
    al.push("c");
    al.push("d");
    al.push("f");
    //使用Iterator迭代器遍历出集合的元素并打印
    for(Iterator i = al.iterator();i.hasNext(); ){
    String str = (String) i.next();
    System.out.println(str);
    }
    }
    _____________________________
    Example added by myself:  
    public class Test { 
     
     public static void main(String[] args) {
      // TODO Auto-generated method stub
      ArrayList list = new ArrayList();
      list.add(0,"aa");
      list.add(1,"bb");
      list.add(2,"cc");
      for(int i=0;i<10;i++)
      {
       
       list.add(Integer.toString(i));
      }
      for(int i=0;i<list.size();i++)
      {
       System.out.println(list.get(i));
      }
      for(Iterator i=list.iterator();i.hasNext();)
       //首先定义一个list对象的Iterator,然后利用该Iterator进行循环迭代操作
      {
       String s =(String)i.next();
       System.out.println(s);
      }
     }
    } 
     
 

Java :List的更多相关文章

  1. Kotlin中变量不同于Java: var 对val(KAD 02)

    原文标题:Variables in Kotlin, differences with Java. var vs val (KAD 02) 作者:Antonio Leiva 时间:Nov 28, 201 ...

  2. Java:类与继承

    Java:类与继承 对于面向对象的程序设计语言来说,类毫无疑问是其最重要的基础.抽象.封装.继承.多态这四大特性都离不开类,只有存在类,才能体现面向对象编程的特点,今天我们就来了解一些类与继承的相关知 ...

  3. 深入理解Java:注解

    注解作用:每当你创建描述符性质的类或者接口时,一旦其中包含重复性的工作,就可以考虑使用注解来简化与自动化该过程. Java提供了四种元注解,专门负责新注解的创建工作. 元注解 元注解的作用就是负责注解 ...

  4. Java:String和Date、Timestamp之间的转

    Java:String和Date.Timestamp之间的转 一.String与Date(java.util.Date)互转 1.1 String -> Date String dateStr  ...

  5. java:访问权限

    访问权限四大类:权限从大->小 1.public:   公共权限 2.protected:  受保护权限 3.default: 包级别访问权限/默认权限 4.private:   私有权限 以p ...

  6. java:比较对象

    对象内容相等条件:1.对象类型相同(可用instanceof操作符比较)2.对象的成员变量的值完全相同 instanceof 判断对象类型 //a是否为Child对象类型 boolean b = a ...

  7. java:复写equals实例

    class User { String name; int age; /* *比较过程思路: *1.两个对象指向位置相同,那么他们就相等,return后跳出函数,不再往下执行 *2.指向位置不同,有3 ...

  8. 【转】深入理解Java:SimpleDateFormat安全的时间格式化

    [转]深入理解Java:SimpleDateFormat安全的时间格式化 想必大家对SimpleDateFormat并不陌生.SimpleDateFormat 是 Java 中一个非常常用的类,该类用 ...

  9. Java:终结器

    目录 背景Java版:终结器防卫者C#版:“终结器防卫者”备注 背景返回目录 多数情况我们不需要重写 finalize 方法,只有当我们需要持有未托管资源的时候才需要,而此时重写 finalize 方 ...

  10. LeetCode第[18]题(Java):4Sum 标签:Array

    题目难度:Medium 题目: Given an array S of n integers, are there elements a, b, c, and d in S such that a + ...

随机推荐

  1. The Best Path---hdu5883(欧拉路径)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5883 题意:n 个点 m 条无向边的图,找一个欧拉通路/回路使得这个路径所有结点的异或值最大. 先判断 ...

  2. Asp.net MVC 中超链接的三个方法及比较

    在Asp.net WebForm开发中,我们通过a标签进行跳转时,通常的写法是:<a href="index.aspx">首页</a>, 在Asp.net ...

  3. 在Fedora8上的Tomcat上deploy一个war

    成龙有个电影叫简单任务,下面要讲的也是简单任务--具体来说是把一个war发布到在Fedora8上的tomcat6上. 在发布之前,需要先配置一个manager角色的任务,否则点Tomcat manna ...

  4. No mapping found for HTTP request with URI [] in DispatcherServlet with name 'appServlet'

    项目是使用SpringMVC (1)在浏览器中访问,后台总报错: No mapping found for HTTP request with URI [] in DispatcherServlet ...

  5. .net中如何使用cookie

    比如建立一个名为aspcn,值为灌水小鱼的cookie HttpCookie cookie = new HttpCookie["aspcn"];cookie.Value = &qu ...

  6. 从printf("\40d\n")看转义字符

    1.  八进制  十进制  十六进制 二进制:0 1 2 3 4 5 6 7    \0(或省略0,\) ,\28 按道理是错误的,但是C语言把它解释为 \2,8错误了就不考虑 十进制:0 1 2 3 ...

  7. 禁用LMHOSTS和NetBIOS后提升上网速度 ?

    LMHOSTS 文件是 windows 中进行 netbios 静态解析时使用的,其作用类型于 HOSTS 文件. 今天发现这个东西有点问题,在用ADSL上网时,明明 IP . DNS 都设置得好好的 ...

  8. Metro之GridView控件的使用-绑定不同的模板样式显示

    最终实现的效果如下: 添加MenuDataSource.cs,字段ImageStyle是用来标识套用的样式 public class MenuGroup { public string GroupTi ...

  9. RabbitMQ学习总结 第六篇:Topic类型的exchange

    目录 RabbitMQ学习总结 第一篇:理论篇 RabbitMQ学习总结 第二篇:快速入门HelloWorld RabbitMQ学习总结 第三篇:工作队列Work Queue RabbitMQ学习总结 ...

  10. 详解Java中的clone方法:原型模式

    转:http://developer.51cto.com/art/201506/478985.htm clone顾名思义就是复制, 在Java语言中, clone方法被对象调用,所以会复制对象.所谓的 ...