Java 泛型和常见的数据结构

2018-12-18  本文已影响0人  啦啦啦_9a5f

一、长度获取:

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

上一篇下一篇

猜你喜欢

热点阅读