java集合总结一
2012-08-22 09:48
232 查看
4月29日 放假前的最后一天,老毕带着我们学习到了IO流,集合部分就这么告一段落了。但我感觉集合这部分的知识自己掌握得不是很好,很多知识点感觉弄混了。感觉集合这块的各个集合之间的方法都像,所以想趁着五一休息这几天,好好总结一下集合这部分知识点。
集合部分总结一
集合
1,集合的由来
面向对象语言对事物的体现都是以对象的形式,所以为了方便对多个对象进行操作,集合就是存储对象最常用的一种方式
数组和集合类同是容器,有何不同
数组虽然也可以存储对象,但长度是固定的:集合长度是可变的。数组中可以存储基本数据类型,集合只能存储对象。
集合类的特点
集合只用于存储对象,集合长度可变,集合可以存储不同类型的对象
参阅顶层,创建底层 原因有两点:
1)不断向上抽取的类是不能创建对象的,是抽象的。
2)子类对象的方法更多
集合框架图
为什么会出现这么多的容器呢?
每一个容器对数据的存储方式都不同,这个存储方式可以称之为数据结构。
一.Collection容器
方法:
1,增加
boolean Add(E e)
boolean addAll(collection c) 一次添加一堆元素
1,)Add方法的参数类型是object 以便于接收任意类型的对象,
2,)集合中存储的都是对象的地址引用
2删除
void clear() 清空容器
boolean remove(Object obj)移除一个元素
boolean removeAll(collection c)移除一堆元素(注意不是移除全部元素)
3,判断
isEmpty() 集合是否为空
boolean retainAll(collection c) 取交集
方法演示
Collection coll = new ArrayList();
//增加元素
coll.add("java001");
coll.add("java002");
coll.add("java003");
coll.add("java004");
System.out.println(coll.add("java005"));//增加元素 返回值为boolean类型
//coll.clear();//清空集合 返回值为void
System.out.println(coll);
System.out.println(coll.size());//返回集合的长度
//删除元素
System.out.println(coll.remove("java002"));//返回值为boolean
System.out.println(coll);
//判断
//1,判断集合是否为空
System.out.println(coll.isEmpty());//当集合size为空时 isEmpty()为true
//2,判断是否包含某一个元素 contains()
System.out.println(coll.contains("java003"));
演示addAll()/ removeAll()/ retainAll()方法
Collection coll = new ArrayList();
//增加元素
coll.add("java001");
coll.add("java002");
coll.add("java003");
coll.add("java004");
Collection coll1 = new ArrayList();
coll1.add("java003");
coll1.add("java004");
coll1.add("java005");
coll1.add("java006");
coll1.add("java007");
coll1.add("java008");
/*System.out.println(coll1.retainAll(coll));
System.out.println(coll1);//仅仅保留两个集合的相同元素
System.out.println(coll);
System.out.println(coll1.removeAll(coll));
System.out.println(coll1);//删除两个集合的相同元素
System.out.println(coll);*/
coll.addAll(coll1);
System.out.println(coll);
什么是迭代器呢?
其实就是集合的取出元素的方式。
Iterator it = coll.iterator();
//接口型引用指向自己的对象 这个对象是通过iterator()方法获取到的
while(it.hasNext())
{
it.next();
}
把取出方式定义在了集合的内部,这样取出方式就可以直接访问集合内部的元素。java电子书免费下载
那么取出方式就被定义成了数据结构不同,所以取出的动作细节也不一样。但是都有共性的内容判断和取出。那么可以将共性的内容取出。
那么这些内部类都符合一个规则。该规则是iterator。那么如何获取集合对象呢?
通过一个对外提供的方法iterator();
for (Iterator it = coll.iterator();it.hasNext();) {
it.next();
} 节省内存
Collection分类
Collection
|---List:元素师有序的,元素可以重复。因为该集合体系有索引
|---Set:元素是无序的,元素不可以重复
List
List特有的方法,凡是可以操作角标的方法都是该体系特有的方法
Set 只有list集合具备这个方法
增:
Add(index,element)
addAll(index,collection)
删
Remove(index)
改
Set(index,element)
查
get(index)
SubList(from,to)
ListIterator();
List集合特有方法演示
List list = new ArrayList();
list.add("java001");
list.add("java002");
list.add("java003");
list.add("java004");
list.add("java005");
//删除元素 根据角标删除元素
//list.remove(2);
//修改元素
list.set(2,"java007");
System.out.println(list);
//获取元素
System.out.println(list.get(1));
System.out.println(list.subList(2,4));//获取子集合 包含头不包含尾
for (int i = 0; i < list.size(); i++) {
System.out.println(list.get(i));
}
集合部分总结一
集合
1,集合的由来
面向对象语言对事物的体现都是以对象的形式,所以为了方便对多个对象进行操作,集合就是存储对象最常用的一种方式
数组和集合类同是容器,有何不同
数组虽然也可以存储对象,但长度是固定的:集合长度是可变的。数组中可以存储基本数据类型,集合只能存储对象。
集合类的特点
集合只用于存储对象,集合长度可变,集合可以存储不同类型的对象
参阅顶层,创建底层 原因有两点:
1)不断向上抽取的类是不能创建对象的,是抽象的。
2)子类对象的方法更多
集合框架图
为什么会出现这么多的容器呢?
每一个容器对数据的存储方式都不同,这个存储方式可以称之为数据结构。
一.Collection容器
方法:
1,增加
boolean Add(E e)
boolean addAll(collection c) 一次添加一堆元素
1,)Add方法的参数类型是object 以便于接收任意类型的对象,
2,)集合中存储的都是对象的地址引用
2删除
void clear() 清空容器
boolean remove(Object obj)移除一个元素
boolean removeAll(collection c)移除一堆元素(注意不是移除全部元素)
3,判断
isEmpty() 集合是否为空
boolean retainAll(collection c) 取交集
方法演示
Collection coll = new ArrayList();
//增加元素
coll.add("java001");
coll.add("java002");
coll.add("java003");
coll.add("java004");
System.out.println(coll.add("java005"));//增加元素 返回值为boolean类型
//coll.clear();//清空集合 返回值为void
System.out.println(coll);
System.out.println(coll.size());//返回集合的长度
//删除元素
System.out.println(coll.remove("java002"));//返回值为boolean
System.out.println(coll);
//判断
//1,判断集合是否为空
System.out.println(coll.isEmpty());//当集合size为空时 isEmpty()为true
//2,判断是否包含某一个元素 contains()
System.out.println(coll.contains("java003"));
演示addAll()/ removeAll()/ retainAll()方法
Collection coll = new ArrayList();
//增加元素
coll.add("java001");
coll.add("java002");
coll.add("java003");
coll.add("java004");
Collection coll1 = new ArrayList();
coll1.add("java003");
coll1.add("java004");
coll1.add("java005");
coll1.add("java006");
coll1.add("java007");
coll1.add("java008");
/*System.out.println(coll1.retainAll(coll));
System.out.println(coll1);//仅仅保留两个集合的相同元素
System.out.println(coll);
System.out.println(coll1.removeAll(coll));
System.out.println(coll1);//删除两个集合的相同元素
System.out.println(coll);*/
coll.addAll(coll1);
System.out.println(coll);
什么是迭代器呢?
其实就是集合的取出元素的方式。
Iterator it = coll.iterator();
//接口型引用指向自己的对象 这个对象是通过iterator()方法获取到的
while(it.hasNext())
{
it.next();
}
把取出方式定义在了集合的内部,这样取出方式就可以直接访问集合内部的元素。java电子书免费下载
那么取出方式就被定义成了数据结构不同,所以取出的动作细节也不一样。但是都有共性的内容判断和取出。那么可以将共性的内容取出。
那么这些内部类都符合一个规则。该规则是iterator。那么如何获取集合对象呢?
通过一个对外提供的方法iterator();
for (Iterator it = coll.iterator();it.hasNext();) {
it.next();
} 节省内存
Collection分类
Collection
|---List:元素师有序的,元素可以重复。因为该集合体系有索引
|---Set:元素是无序的,元素不可以重复
List
List特有的方法,凡是可以操作角标的方法都是该体系特有的方法
Set 只有list集合具备这个方法
增:
Add(index,element)
addAll(index,collection)
删
Remove(index)
改
Set(index,element)
查
get(index)
SubList(from,to)
ListIterator();
List集合特有方法演示
List list = new ArrayList();
list.add("java001");
list.add("java002");
list.add("java003");
list.add("java004");
list.add("java005");
//删除元素 根据角标删除元素
//list.remove(2);
//修改元素
list.set(2,"java007");
System.out.println(list);
//获取元素
System.out.println(list.get(1));
System.out.println(list.subList(2,4));//获取子集合 包含头不包含尾
for (int i = 0; i < list.size(); i++) {
System.out.println(list.get(i));
}
相关文章推荐
- 【Java集合的详细研究1】Collections类常用方法总结
- java集合基础总结
- java之集合框架总结
- java中集合总结
- Java_基础—集合的总结
- 集合框架。。。。java知识总结(工作一年半差不多两年了,感觉是时候总结一下java,文章内容为本人观点)
- 关于Java集合总结
- Java集合和数组的排序方式总结
- java基础学习之集合概念总结
- java--集合框架总结1--set总结
- Java基础6:集合框架学习总结
- 小小的总结一下java异常处理和List、ArrayList、Vector、Set、HashSet、TreeSet集合的简单应用
- Java 集合系列之 Map总结(HashMap, Hashtable, TreeMap, WeakHashMap等使用场景)
- java对集合和迭代的操作基础总结
- Java中集合的常用类用法总结
- Java集合-04之 fail-fast总结(通过ArrayList来说明fail-fast的原理、解决办法)
- Java单列集合总结
- Java-集合框架总结
- Java通用程序设计与集合方法总结
- Java数据结构与算法之数据结构-逻辑结构-集合(七)------集合之Set接口和HashSet和TreeSet、LinkedHashSet实现类总结