一、整体结构

Collection接口为一些单列集合的根接口,其常用子接口为List接口、Set接口。List接口常用实现子类为ArrayList(数组)
LinkedList(链表)。Set接口常用实现子类为HashSet(哈希表)LinkedHashSet(哈希表和链表结合)。

二、Collection接口

Collection接口作为根接口,为我们提供了集合的一些常用操作:
(1)增加、add(E e) - 返回值为boolean(是否添加成功)。
(2)清除、clear() - 除去此数组的所有操作。
(3)是否包含某一元素、contains(Object o) - 如果包含返回为true(可以用于进行if判断),如果集合里边的元素为自定义
类的话需要重写自定类的equals方法(contains方法就是基于equals实现的)否则比较的是地址。
(4)比较此collection与指定对象是否相等、equals(Object o) - 返回值为boolean(true为相等)。
(5)此collection是否包含某元素、isEmpty() - 返回值为boolean(true为不包含)。
(6)获取此collection的迭代器、iterator() - 用于遍历集合(此迭代器只能遍历集合,不能对集合进行修改,否则会报并发
修改异常-ConcurrentModificationException)。
(7)删除指定元素、remove(Object o) - 返回值为boolean(true表示删除成功)。
(8)返回元素数(集合的长度)、size() - 返回值为int(集合中元素的个数)。
(9)返回此集合中所有元素的数组、toArray() - 返回值是一个数组。

举例:

 public static void main(String[] args) {
//创建集合,这里为多态-向下转型
Collection a = new ArrayList();
//在集合里添加元素
a.add("hello");
a.add("world");
//获取此集合的迭代器
Iterator iterator = a.iterator();
//通过迭代器遍历集合
while (iterator.hasNext()) {
String s = (String) iterator.next();
System.out.println(s);
}
//集合里是否包含"hello"元素
System.out.println(a.contains("hello"));
//这个是调皮的分割线
System.out.println("---------------------------");
System.out.println(a.isEmpty());
System.out.println("---------------------------");
//删除某元素
a.remove("world");
System.out.println(a);
//清空集合
a.clear();
System.out.println(a);
}

三、List接口

List派系的数组特点为有序、具有索引、可以重复。他可以使用其父的所有方法,同时他还有一些自己的方法:
(1)根据索引返回指定位置的元素、get(int index) - 返回值为指定位置的元素。
(2)返回第一次出现指定元素的索引、indexOf(Object o) - 返回值为int(索引如果不存在则返回-1)。
(3)返回最后一次出现指定元素的索引、lastIndexOf(Object o) - 返回值为int(索引如果不存在则返回-1)。
(4)获取此列表的迭代器、listIterator() - 用于遍历集合(此迭代器同iterator()的别在于,此迭代器可以对
数组进行增加等操作,因为ListIterator遍历的元素所在的容器都有索引)。
(5)替换指定索引位置的元素、set(int index, E element)。
举例:

 public static void main(String[] args) {
// 创建集合
List c = new ArrayList();
// 添加元素
c.add("aaaa");
c.add("wqe");
c.add("eqw");
c.add("eqwe");
c.add("aatyaa");
// 获取迭代器
ListIterator iterator = c.listIterator();
while (iterator.hasNext()) {
String s = (String) iterator.next();
//如何集合里遇到"aaaa",则添加元素"哈哈哈哈"
if (s.equals("aaaa")) {
iterator.add("哈哈哈哈");
}
}
System.out.println(c);
}

1、ArrayList类

ArrayList类可以使用Collection、List的全部方法,具有List的特点-有序、具有索引、可以重复。常用的构造
方法:ArrayList<泛型> 变量名=new ArrayList<>();

2、LinkedList类

LinkedList类为List接口的链表实现,常用构造方法与一般的集合一样,而除了其根类的方法外还有其自己的独有方法:
(1)将元素添加到集合开头、addFirst(E e)。
(2)将元素添加到集合结尾、addLast(E e)。
(3)返回此集合的第一个元素、getFirst()。
(4)返回此集合的最后一个元素、getLast()。
(5)返回此集合中最后出现的指定元素的索引、lastIndexOf(Object o) - 返回值为int(索引)。
(6)移除并返回此列表的最后一个元素、removeLast() - 返回值为被删除的元素。
举例:

 public static void main(String[] args) {
LinkedList ll = new LinkedList();
ll.add("hello");
ll.add("world");
// 再集合首位增加元素
ll.addFirst("java");
System.out.println(ll);
// 再集合末位增加元素
ll.addLast("py");
System.out.println(ll);
// 获取末尾索引的元素
System.out.println(ll.getLast());
// 获取首位索引位置
System.out.println(ll.getFirst());
// 删除末尾元素
ll.removeLast();
System.out.println(ll);
// 删除首位元素
ll.removeFirst();
System.out.println(ll);
// contains里边用的也是equals方法比较,比的是谁。用的谁的equals
boolean b = ll.contains("hekko");
}

四、Set接口

Set接口则是Collection里的另一个派系,Set派系的特点是无序的、没有索引、不能重复。同样的他也可以
使用Collection接口的全部方法。(学习类和方法时要从根开始学可以减少很多的无用功)。

1、HashSet

此类是以哈希表结构为基础,不保证其迭代顺序,所以说是无序的。
其常用初始化方法:HashSet< > 变量名=new HashSet<>();
举例:

 //主方法
public static void main(String[] args) {
//创建集合
HashSet<Student> ah = new HashSet<>();
//添加元素
Student student = new Student("zhangsan1", 11);
Student student2 = new Student("sA", 1313);
Student s3 = new Student("sA", 1313);
ah.add(student2);
ah.add(student);
ah.add(s3);
for (Student s1 : ah) {
System.out.println(s1);
}
}
 //学生类
class Student {
String name;
int age; public Student() {
super();
// TODO Auto-generated constructor stub
} public Student(String name, int age) {
super();
this.name = name;
this.age = age;
} @Override
public String toString() {
return "Student [name=" + name + ", age=" + age + "]";
} @Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + age;
result = prime * result + ((name == null) ? 0 : name.hashCode());
return result;
} @Override
public boolean equals(Object obj) {
if (this == obj)
return true;
if (obj == null)
return false;
if (getClass() != obj.getClass())
return false;
Student other = (Student) obj;
if (age != other.age)
return false;
if (name == null) {
if (other.name != null)
return false;
} else if (!name.equals(other.name))
return false;
return true;
}
}

注意:这里如果你自己定义的学生类就要重写hashCode和equals方法,因为add()方法底层默认比对的是其地址值,所
以每个对象一定是不同的,就会有重复的情况。而重写了hashCode和equals方法后,他会根据自定义类里的属性
生成hashCode,如果相同在比较地址或equals。如果都相同则被认定为重复。
(1)重写hashCode和equals方法的快捷方式:
Alt+Shift+S,在按h或鼠标选择重写hashCode和equals。
(2)判断是否重复的源码逻辑:
if (e.hash == hash && ((k = e.key) == key || key.equals(k)))

2、LinkedHashSet类

此类是哈希表和链表的结合,因此他具有不可重复、有序的特点。如果需要对数组进行去重,但是还不能改变数组中原来
数字的大小顺序就可以用这个类。
举例:

 public static void main(String[] args) {
int[] arr = { 1, 2, 3, 4, 5, 1, 2, 6, 7, 10 };
// 定义集合
LinkedHashSet<Integer> lh = new LinkedHashSet<>();
for (int i = 0; i < arr.length; i++) {
lh.add(arr[i]);
}
//遍历集合
for (Integer integer : lh) {
System.out.println(integer);
}
}

JAVA基础-集合(一)的更多相关文章

  1. JAVA基础-集合(二)

    一.Map整体结构体系 Map是集合的另一大派系,与Collection派系不同的是Map集合是以键值对儿的形式存储在集合的.两个键为映射关系,其中第一个键为主键(主键是唯一的不可重复),第二个键为v ...

  2. Java基础-集合的嵌套

    Java基础-集合的嵌套 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.静态导入 静态导入是在JDK1.5后的新特性,可以减少开发的代码量,但是实际用处是很一般,静态导入的标准 ...

  3. Java基础——集合框架

    Java的集合框架是Java中很重要的一环,Java平台提供了一个全新的集合框架.“集合框架”主要由一组用来操作对象的接口组成.不同接口描述一组不同数据类型.Java平台的完整集合框架如下图所示: 上 ...

  4. java基础---集合(1)

    一. 基本概念 集合.数组都是对多个数据进行存储操作的结构,简称Java容器 数组:长度确定,类型确定,对于添加.删除.插入等操作效率不高,元素有序可重复 Java中集合框架顶层框架是:java.ut ...

  5. Java基础——集合源码解析 List List 接口

    今天我们来学习集合的第一大体系 List. List 是一个接口,定义了一组元素是有序的.可重复的集合. List 继承自 Collection,较之 Collection,List 还添加了以下操作 ...

  6. Java基础—集合

    一.概述 Java中的集合框架主要分为两大派别:Collection 和 Map —— 位于util包下 类的基础关系图如下(图片来自百度) 常用: List——有序可重复 Set——无序不可重复 M ...

  7. java基础集合简介Set(三)中

    今天主要说夏set集合,每天抽出一个小时总结下,生活会更加美好! --< java.util >-- Set接口: 数据结构:数据的存储方式: Set接口中的方法和Collection中方 ...

  8. java基础集合经典训练题

    第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...

  9. 十七、Java基础---------集合框架之Map

    前两篇文章中介绍了Collection框架,今天来介绍一下Map集合,并用综合事例来演示. Map<K,V> Map<K,V>:Map存储的是键值对形式的元素,它的每一个元素, ...

  10. 十六、Java基础---------集合框架之Set

    写在前面的话,这篇文章在昨天就写好了,今天打开的时候一不小心将第二天的文章粘贴到了这篇文章,很不幸的是除了标题之外依然面目全非,今天带着沉痛的心情再来写这篇文章! 上篇文章介绍了Collection体 ...

随机推荐

  1. 木棍分割[HAOI2008]

    题目描述 有n根木棍, 第i根木棍的长度为Li,n根木棍依次连结了一起, 总共有n-1个连接处. 现在允许你最多砍断m个连接处, 砍完后n根木棍被分成了很多段,要求满足总长度最大的一段长度最小, 并且 ...

  2. 关于Python3中venv虚拟环境

    Python3.3以上的版本通过venv模块原生支持虚拟环境,可以代替Python之前的virtualenv. 该venv模块提供了创建轻量级"虚拟环境",提供与系统Python的 ...

  3. sql 日记

    --4.选择雇用时间在1998-02-01到1998-05-01之间的员工姓名,job_id和雇用时间select last_name,job_id,hire_datefrom employeeswh ...

  4. mysqli数据库连接

    /* * 连接数据库的mysqli函数库 * 使用的是过程化的风格编码 */header('content-type:text/html;charset=utf-8');// 获取数据库连接$link ...

  5. 小A点菜 洛谷 p1164

    题目背景 uim神犇拿到了uoi的ra(镭牌)后,立刻拉着基友小A到了一家--餐馆,很低端的那种. uim指着墙上的价目表(太低级了没有菜单),说:"随便点". 题目描述 不过ui ...

  6. 纯CSS实现table表头固定(自创备忘)

    因为之前约定时候产品没说要表头固定,这次迭代测试突然提出这个需求,而且不知道因为什么未知原因非要这样不可--因为之前用了table标签做表单,而且也没用插件,这下就难了点,找另外一个前端前辈妹子商量了 ...

  7. Hexo快速部署教程

    一直有建立博客的需要,使用过Wordpress动态博客,一直访问速度比较慢,刚开始以为是空间域名的解析的问题,尝试使用Hexo静态博客,部署后感觉速度正常很多,特意发文快速部署教程 准备 本文是在wi ...

  8. JavaScript之去除前后空格//g

    使用正则表达式"//g"去除字符串中的前后空格."//"表示所要匹配的字符串,如前后空格为/^\s*|\s*$/,这里"^"表示以" ...

  9. java核心技术之流与文件

    InputStream和OutputStream构成了输入/输出类层次结构的基础.用于按字节进行读写.而与之处在同一等级的Reader/Writer同样作为抽象类定义了用于对字符进行读取的类层次结构, ...

  10. sublime text 的小细节设置,让你的代码更优美

    这些属性都可以在 首选项>设置-默认 里修改下面也会介绍几个比较常用的几个插件 字体大小: "font_size": 17 高亮编辑中的一行 "highlight_ ...