集合:对象的容器,定义了对多个对象进行操作的常用方法。可实现数组的功能

集合和数组的区别:

  • 数组长度固定,集合长度不固定
  • 数组可以存储基本数据类型和引用数据类型,集合只能存储引用数据类型。

集合的位置:java.util.*;

Collection体系集合:

Collection父接口:

特点:代表一组任意类型的对象,无序,无下标,不能重复

方法:

  • boolean add(Object o)  //添加一个对象
  • boolean addAll(Collection c)  //将一个集合中的所有对象添加到此集合中
  • void clear()     //清空此集合中的所有对象
  • boolean contains(Object o)     // 检测此集合中是否包含o对象
  • boolean equals(Object o)     //比较此集合中是否与指定对象相等
  • boolean isEmpty()       //判断此集合是否为空
  • boolean remove(Object o)     //在此集合中移出o对象
  • int size()     //返回此集合中的元素个数
  • Object[] toArray()  //将此集合转换成数组

使用;

package com.java.leetcode.collection;
/*
Collection接口的使用
添加,删除,遍历,判断
*/ import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator; public class Demo01 {
public static void main(String[] args) {
//创建集合
Collection collection = new ArrayList();
//添加
collection.add("苹果");
collection.add("香蕉");
collection.add("梨");
System.out.println("当前元素个数:"+collection.size());
System.out.println(collection);
/*
遍历元素
1.使用增强for。不能用for,因为collection没有下标。
*/
System.out.println("********使用增强for********");
for (Object object:collection) {
System.out.println(object);
}
/*
2.使用迭代器(专门用来遍历集合的一种方法)
Iterator是一个接口,没有实现类,通过以下方法实现集合的遍历
hasNext() 如果仍有元素可以迭代,则返回true
next() 返回迭代的下一个元素
remove() 从迭代器指向的collection中移除迭代器返回的最后一个元素
在迭代器中只能使用迭代器的移除方法,不能用collection的
*/
System.out.println("********使用迭代器********");
Iterator iterator =collection.iterator();
while (iterator.hasNext()){
String object = (String)iterator.next();
System.out.println(object);
}
System.out.println("是否有苹果?"+collection.contains("苹果"));
System.out.println("是否有榴莲?"+collection.contains("榴莲"));
collection.remove("香蕉");
System.out.println(collection);
collection.clear();
System.out.println(collection);
}
}

运行结果:

List子接口

特点:有序,有下标,元素可以重复。

方法:

  • void add(int index,Object o)   //在index位置插入对象o
  • boolean addAll(int index,Collection c)   //将一个集合中的元素添加到此集合中的index位置
  • Object get(int index)   //返回集合中指定位置的元素
  • List subList(int fromIndex,int toIndex)   //返回fromIndex和toIndex之间的集合元素。

1.

package com.java.leetcode.collection;

import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import java.util.ListIterator;
/*
List子接口
特点:有序,有下标,元素可以重复
*/
public class Demo02 {
public static void main(String[] args) {
//创建集合对象
List list = new ArrayList();
//添加元素
list.add("苹果");
list.add("香蕉");
list.add("榴莲");
list.add("火龙果");
list.add("黄桃");
System.out.println("元素个数"+list.size());
System.out.println("元素内容:"+list.toString());
//删除元素
list.remove("苹果");
list.remove(1); //因为list有下标,可以通过下标删除。苹果删除之后,下标为1的是榴莲
System.out.println("删除之后:"+list.toString());
//遍历,使用for遍历
System.out.println("*******使用for循环遍历*******");
for (int i = 0; i <list.size(); i++) {
System.out.println(list.get(i)); //此处get返回的是Object类型
}
System.out.println("*******使用增强for遍历*******");
for (Object o:list ) {
System.out.println(o);
}
System.out.println("*******使用迭代器遍历*******");
Iterator it = list.iterator();
while (it.hasNext()){
System.out.println(it.next());
}
/*
接口 ListIterator<E>
方法:
void add(E e) //将指定的元素插入列表。
boolean hasNext() //以正向遍历列表时,如果列表迭代器有多个元素,则返回true。
boolean hasPrevious //如果以逆向遍历列表,列表迭代器有多个元素,就返回true。
E next() //返回列表中的下一个元素
int nextIndex() //返回对nxt的后续调用所返回元素的索引。
E previous() //返回列表的前一个元素
int PreviousIndex() //返回对previous的后续调用所返回元素的索引
void remove() //从列表中移除由next或previous返回的最后一个元素
void set(E e) //用指定元素替换next或previous返回的最后一个元素
*/
System.out.println("*******使用列表迭代器从前往后遍历*******");
ListIterator lit = list.listIterator();
while (lit.hasNext()){
System.out.println("下标"+lit.nextIndex()+":"+lit.next());
}
System.out.println("*******使用列表迭代器从后往前遍历*******");
while (lit.hasPrevious()){ //此时经历上面从前往后的遍历后,指针已经走到了列表的最后
System.out.println("下标"+lit.previousIndex()+":"+lit.previous());
}
//判断 contains
System.out.println();
System.out.println("苹果是否存在?"+list.contains("苹果"));
System.out.println("列表是否为空?"+list.isEmpty());
//获取位置
System.out.println("黄桃的位置:"+list.indexOf("黄桃"));
}
}

运行结果:

2.

package com.java.leetcode.collection;

import java.util.ArrayList;
import java.util.List; public class Demo03 {
public static void main(String[] args) {
List list = new ArrayList();
/*
添加数字数据(自动装箱)
集合只能存储引用数据类型,不能存储基本数据类型。
在向集合添加基本数据类型时,会自动装箱。
例如list.add(200); 该200已经不是基本数据的int 的200了,而是包装类Integer
*/
for (int i = 0; i <=100 ; ) {
list.add(i);
i = i+10;
}
System.out.println("元素个数:"+list.size());
System.out.println("元素内容:"+list);
// list.remove(20);这里会报IndexOutOfBoundsException异常,因为列表大小为11,而这里传入的20 认为是下标
list.remove((Object)20);
System.out.println("删除之后:"+list);
list.remove(new Integer(0)); //Integer是包装类,是一个类。
System.out.println("删除之后:"+list);
//subList,返回子集合,含头不含尾
List sublist = list.subList(1,5);
System.out.println(sublist);
}
}

运行结果

 List实现类:

  ArrayList;

  • 数组结构实现,查询快,增删慢
  • JDK1.2版本,运行效率快,线程不安全

  Vector:

  • 数组结构实现,查询快,增删慢
  • JDK1.0版本,运行效率慢,线程安全

  LinkedList:

  • 链表结构实现,增删快,查询慢
  • 是一个双向链表

集合——Collection接口,List接口的更多相关文章

  1. java集合 之 Collection和Iterator接口

    Collection是List,Queue和Set接口的父接口,该接口里定义的方法即可用于操作Set集合,也可以用于List和Queue集合.Collection接口里定义了如下操作元素的方法. bo ...

  2. JAVA集合详解(Collection和Map接口)

    原文地址http://blog.csdn.net/lioncode/article/details/8673391 在JAVA的util包中有两个所有集合的父接口Collection和Map,它们的父 ...

  3. JAVA集合--Collection接口

        本文首发于cartoon的博客     转载请注明出处:https://cartoonyu.github.io/cartoon-blog     在概述里面也说过:Collection是jav ...

  4. 集合-Collection接口

    集合 和 数组 的比较: 数组 - 本质上就是在内存空间中申请的一段连续内存空间,存放多个相同类型的数据 - 数组一旦定义完毕,则在内存空间中的长度固定. - 插入/删除元素时可能导致大量元素的移动, ...

  5. 集合--Collection接口详解&&迭代器

    /* * 集合的顶层接口--Collection接口 * 添加 * add() * addAll() * * 遍历集合 * iterator() 迭代器 * * 删除 * remove() * rem ...

  6. Java中的集合(六)继承Collection的Set接口

    Java中的集合(六)继承Collection的Set接口 一.Set接口的简介 Set接口和List接口都是继承自Collection接口,它与Collection接口中功能基本一致,并没有对Col ...

  7. Java中的集合(五)继承Collection的List接口

    Java中的集合(五)继承Collection的List接口 一.List接口简介 List是有序的Collection的,此接口能够精确的控制每个元素插入的位置.用户能够根据索引(元素在List接口 ...

  8. Java中的集合(三)继承Collection的Queue接口

    Java中的集合(三)继承Collection的Queue接口 一.Queue介绍 Queue接口继承自Collection接口,是Java中定义的一种队列数据结构,元素是有序的(按插入顺序排序),先 ...

  9. java集合(2)-Collection与Iterator接口

    1 package com.j1803.collectionOfIterator; 2 import java.util.ArrayList; 3 import java.util.Collectio ...

随机推荐

  1. python连接mongodb数据库

    之前使用过python连接mysql数据库(用到pymysql库),公司也有使用mongodb数据库,所以就整理了一份python连接mongodb数据库的代码出来,以供记录和分享. 首先我们要用到 ...

  2. 如何绑定msix中断 cpu亲和性

    echo X > /proc/irq/中断号/smp_affinity /proc/irq目录下面会为每个注册的irq创建一个以irq编号为名字的子目录,每个子目录下分别有以下条目:1.smp_ ...

  3. Python编写简易木马程序(转载乌云)

    Python编写简易木马程序 light · 2015/01/26 10:07 0x00 准备 文章内容仅供学习研究.切勿用于非法用途! 这次我们使用Python编写一个具有键盘记录.截屏以及通信功能 ...

  4. Configuration problem: 'bean' or 'parent' is required for <ref> element

    我出现此错误的原因是web.xml中没有指定spring的启动配置文件applicationContext.xml的加载位置.applicationContext.xml原来再webRoot/webI ...

  5. 转:C++11常用新特性快速一览

    转载至:https://blog.csdn.net/jiange_zh/article/details/79356417 1.nullptr nullptr 出现的目的是为了替代 NULL. 在某种意 ...

  6. spring boot 实现优雅的关闭

    1.导入jar包 <dependency> <groupId>org.springframework.boot</groupId> <artifactId&g ...

  7. 经历了源码的痛苦,掌握DRF的核心序列化器

    目录 DRF的核心--序列化器 序列化器 什么是序列化和反序列化? 序列化 序列化demo 字段类型 字段参数 序列化自定制返回字段 方法一:在序列化类(serializers.py)中写 方法二:在 ...

  8. IMWebConf 2017 官网彩蛋解谜

    前言 IMWebConf 2017 ←这是官网 然后看到了这个: 所以就试了下,作为一个前端菜鸟,发现通关还挺简单的,不过每个方面的知识都涉及到一点,所以在这里总结一下. 下面进入正题. 第 0 关 ...

  9. 微信小程序wx.login()获取openid,附:前端+后端代码

    微信小程序开放了微信登录的api,无论是个人还是企业申请的小程序均可使用. 首先创建一个项目,把这些代码都清空,我们自己写! 然后,开始写了!首先index.wxml,写一个button用于发起登录 ...

  10. 利用Charles做代理测试电脑上写的H5页面

    做H5页面的同学可能经常会遇到一个场景,就是电脑上调试好的页面怎么在手机上访问测试呢? 下面就介绍一种自己经常使用的方式,利用Charles代理软件来实现! 安装Charles 直接去官网下载对应的系 ...