Java集合的概述
集合、数组都是对多个数据进行存储操作的结构,简称Java容器。
Java集合框架提供了一套性能优良、使用方便的接口和类,它们位于Java.util包中。
集合相对于数组的优点:集合长度可变,添加、删除和插入时效率高。
集合框架
Conlection接口的两个子接口 List 和 Set ;
Conlection 接口存储一组不唯一,无序的对象;
List接口存储一组不唯一,有序(插入顺序)的对象。有序的对象,类似数组的下标,但是集合比数组更灵活。
Set接口存储一组唯一,无序的对象。
List集合中常用的两个ArrayList、LinkedList.
实现了长度可变的数组,在内存中分配连续的空间,遍历元素和随机访问元素的效率比较高。
LinkedList采用链表存储方式,插入、删除元素时效率比较高。
数组常用的方法使用
public class ListTest {
public static void main(String[] args) {
//创建ArrayList集合对象
ArrayList list = new ArrayList();
//创建对象使用add()方法添加到list集合中
list.add(new NewsTittle(1,"第一个景点","作者1"));
list.add(new NewsTittle(2,"第二个景点","作者2"));
list.add(new NewsTittle(3,"第三个景点","作者3"));
list.add(new NewsTittle(4,"第四个景点","作者4"));
list.add(new NewsTittle(5,"第五个景点","作者5"));
//获取新闻的总数 size()方法获取集合的长度
System.out.println("新闻总数量---->"+list.size());
//for循环遍历集合
for (int i = 0; i < list.size(); i++) {
//使用get()方法获取集合中的对象
//因为get()方法获取的集合时Object类型的所以需要类型转换
NewsTittle tittle = (NewsTittle) list.get(i);
System.out.println("新闻标题 "+tittle.getTittle());
}
//增强for循环遍历
for (Object obj:list) {
NewsTittle tittle = (NewsTittle) obj;
System.out.println("新闻标题 "+tittle.getTittle());
}
}
}
LinkedList和ArrayList共用的add(),get(),size()方法,在此就不给大家举例了
LinkedList还有一些独有的方法:
1.void addFist(Object o) 在列表首部添加元素。
2.void addLast(Object o) 在列表的末尾添加元素。
3.Object getFist() 返回别表中的第一个元素。
4.Object getLast() 返回别表中的最后一个元素。
5.Object removeFirst() 删除并返回列表的第一个元素。
6.Object removerLast() 删除并返回列表的最后一个元素。
Set
Set接口存储一组唯一,无序的对象。HashSet时Set接口中常用的实现类
Set中存放对象的引用,采用对象的equals()方法比较两个对象是否相同。
HashSet的使用:
public class ListTest {
public static void main(String[] args) {
Set set = new HashSet();
//创建对象并且添加到list集合中
set.add(new NewsTittle(1,"第一个景点","作者1"));
set.add(new NewsTittle(2,"第二个景点","作者2"));
set.add(new NewsTittle(3,"第三个景点","作者3"));
set.add(new NewsTittle(4,"第四个景点","作者4"));
set.add(new NewsTittle(5,"第五个景点","作者5"));
//获取新闻的总数
System.out.println("新闻总数量---->"+set.size());
//增强for循环遍历因为Set时无序的,所以遍历出来是乱序的。
for (Object obj:set) {
NewsTittle tittle = (NewsTittle) obj;
System.out.println("新闻标题 "+tittle.getTittle());
}
}
}