美文网首页
Java 泛型和常见的数据结构

Java 泛型和常见的数据结构

作者: 啦啦啦_9a5f | 来源:发表于2018-12-18 16:15 被阅读0次

    一、长度获取:

    1.array length

    2.字符串长度 length()

    3.ArrayList长度 size()

    二、集合的体系结构:

    1.由于不同的数据结构(数据的组织,存储方式),所以Java为我们提供了不同的集合

    但是不同的集合功能是相似的,不断向上提取,将共性抽取出来,这就是集合体系结构形成的原因

    2.体系结构:

    怎么学习?从最顶层开始学习,最顶层包含所有的共性

    怎么使用?使用最底层,因为最底层就是具体的实现

    Collection-->List-->ArrayList

    三、Collection中的常用功能

    1.Collection接口,不同集合存储数据的方式不同,Collection只能定义一些规范

    2.boolean add(E e)//永远可以添加成功,ArrayList 允许重复

    3.void clear()//清空集合

    4.boolean contains(Object o)//是否包含某个元素

    5.boolean isEmpty()//是否为空

    6.boolean remove(Object o)// 删除元素

    7.int size()

    8.Object[] toArray():将集合转换成object数组

    四、集合中可以存任意引用型对象

    Iterator<E> iterator

    List l = new ArrayList();

    ListIterator it = l.ListIterator();//l为collection对象
    while(it.hasNet()){
      string s = (string)it.next();
      if(s.equals("java")){
      it.add("android");
    }
    }

    迭代器是依赖于集合的,相当于集合的一个副本,当迭代器在操作的时候,如果发现和集合不一样,则抛出异常。就是说如果直接往集合中添加新的元素,迭代器发现集合与自身不同,就会抛出异常,这时候正确的做法应该是往迭代器中添加元素,然后迭代器再去更新集合。由于Iterator中没有添加元素的方法,所以用其子类ListIterator,这是一个接口。

    五、使用集合存储自定义对象并遍历

    由于集合可以存储任意类型的对象,就有可能在转换是出现类型转换异常,所以Java为了解决这个问题,给我们提供了一种机制,叫做泛型。

    1.泛型:是一种广泛的类型,把明确数据类型的工作提前到了编译时期,借鉴了数组的特点。

    2.泛型的好处:避免了类型转换错误到运行时期才发现的

    3.foreach

    (1)增强for循环,一般用于遍历集合或者数组

    (2)格式:

      for(元素的类型变量:集合或者数组对象){

        可以直接使用变量;

      }

    for(Object obj : c){
      System.out.println(obj);
    }

    注意:在集合中for循环中不能修改集合,否则会出现并发修改异常。增强for底层是迭代器

    六、常见数据结构:

    1.数组的特点:

    (1)数组的长度一旦定义则不能改变

    (2)数组中的元素都有 整数索引

    (3)数组只能存储同意类型的元素

    (4)数组既可以存储基本数据类型,也可以存储引用类型

    想要在元素3后面添加一个新的元素?

    创建一个新的数组,长度是原先数组长度+1

    查找快,增删慢

    2.栈:先进后出

    3.队列:先进先出

    七、List

    1.特点:

    有序的(存储和读取的顺序是一致的)

    有整数索引

    允许重复

    2.List的特有功能:

    void add(int index,E element) :在指定索引位置添加指定元素

    E get(int index):根据索引返回元素

    E remove(int index):删除指定元素并返回

    E set(int index,E element):将指定索引位置的元素替换为指定元素,并将原先的元素返回

    3.List的常用子类:

    (1)ArrayList:

    底层是数组节后,查询快,增删慢

    (2)LinkedList:

    底层结构是链表,查询慢,增删快

    void addFirst(E e)
    void addLast(E e)
    E getFirst()
    E getLast()
    E removeFirst()
    E removeLast()

    使用这些方法模拟栈和队列

    (3)如何选择使用不同的集合?

    查询多、增删少,使用ArrayList

    查询少、增删多,使用LinkedList

    如果不知道使用什么,使用ArrayList

    相关文章

      网友评论

          本文标题:Java 泛型和常见的数据结构

          本文链接:https://www.haomeiwen.com/subject/plylkqtx.html