单例集合体系:

---------| collection  单例集合的根接口
--------------| List  如果实现了list接口的集合类,具备的特点:有序,可重复       注:集合中的有序不是指自然顺序,而是指添加进去的顺序与出来的顺序是一致的
------------------| ArrayList  ArrayList底层维护了一个object数组的实现的。(线程不安全),特点:查询速度快,增删速度慢。有序,可重复
------------------| LinkedList  LinkedList底层是使用链表结构实现的,线程不安全,特点:查询速度慢,增删速度快。有序,可重复
------------------| Vector(了解即可)  底层也是维护一个Object数组的实现的,实现与ArrayList是一样的,但是Vector是线程安全的,操作效率低
--------------| Set  如果实现了set接口的集合类,具备的特点:无序,不可重复     注:集合中的无序不是指自然顺序,而是指添加元素进去的顺序与元素出来的顺序是不一致的
------------------| HashSet  底层是用于一个哈希表支持的。线程不安全,特点:存储速度块
------------------| TreeSet  底层是使用红黑树(二叉树)数据结构实现的,线程不同步(即线程不安全),不能在多线程中共享,但可以使用synchroinzedMap()方法来实现同步。特点:会对元素进行排序存储(按自然顺序

双例集合体系:

----------| Map  双例集合的根接口。如果是实现了Map接口的集合类,具备的特点:存储的数据都是以键值对形式存在的,键不可重复,值可以重复
--------------| HashMap  底层是基于哈希表实现的,HashMap允许键和值为null,线程不安全,特点:存储速度块
--------------| TreeMap  基于红黑数(二叉树)数据结构实现的,线程不同步(即线程不安全),特点:会对元素经行排序存储
--------------| HashTable(了解即可)   线程安全


一、List 集合

1.1、List接口中的特有方法

  添加:
      add(E, e) :将指定的元素追加到此列表的末尾
      add(int index, E element) :将指定的元素插入此列表中的指定位置
      addAll(Collection<? extends E> c):按指定集合的迭代器返回的顺序,将指定集合中的所有元素添加到此(集合)列表的末尾。
  获取:
      get(int index): get方法获取元素
      indexOf(Object o): 找出指定元素第一次出现在集合中,指定的索引值,如果此列表不包含元素,则返回-1。
      lastIndexOf(Object o):返回此列表中指定元素的最后一次出现的索引,如果此列表不包含元素,则返回-1。
      subList(int fromIndex, int toIndex):截取 包前不包后

  修改:
      subList(int fromIndex, int toIndex):截取 包前不包后。
      add(int index, E element) :将指定的元素插入此列表中的指定位置;如果插入到已有元素的索引值下,则相当于替换原有的数据。
      set(int index, E element):用指定的元素替换此列表中指定位置的元素

1.2、List集合具备的特点

    有序,可重复性  

注意:集合中的有序不是指自然顺序,而是指添加进去的顺序与出来的顺序是一致的

1.3、List接口中方法具备的特点

操作的方法都存在索引值,只有list下面的集合才具备索引值;其他接口下面的集合类都没有索引值

1.4、实例

 package com.zn.collection;

 import java.util.ArrayList;
import java.util.Iterator;
import java.util.List; /**
* @author DSHORE / 2018-5-16
*
*/
public class Demo5 {
public static void main(String[] args) {
//假设原有的List集合有这四调数据
List<Object> list = new ArrayList<Object>();
list.add("张三");
list.add("李四");
list.add("王五");
list.add("赵六"); //添加
list.add(,"老七");
System.out.println(list);//返回值:[张三, 老七, 李四, 王五, 赵六];说明“老七”把“李四”替换了
List<Object> list2 = new ArrayList<Object>();
list2.add("安其拉");
list2.add("亚瑟");
list2.add("赵云");
list.addAll(list2);//把list2集合中的数据添加到list集合中
System.out.println(list);//返回值:[张三, 老七, 李四, 王五, 赵六, 安其拉, 亚瑟, 赵云] //获取
System.out.println("get方法根据索引值获取到的元素:"+list.get());//返回值:李四
for (int i = ; i < list.size(); i++) {//集合用size();数组用length。
//集合用get(i);数组用get[i]。
System.out.print(list.get(i)+",");//返回值:张三,老七,李四,王五,赵六,安其拉,亚瑟,赵云,
}
System.out.println();//换行
System.out.println(list.indexOf("赵六"));//返回值:4
System.out.println(list.indexOf("六六"));//返回值:-1 说明:list集合列表中没有该数据,所以返回值为-1
System.out.println(list.lastIndexOf("安其拉"));//返回值:5 //修改
System.out.println(list.subList(,));//返回值:[老七, 李四, 王五] 说明:subList()截取函数;包前不包后
list.set(,"二狗子");
/*//方式1:
for (int i = 0; i < list.size(); i++) {
System.out.print(list.get(i)+",");//返回值:张三,二狗子,李四,王五,赵六,安其拉,亚瑟,赵云,
}*/
//方式2
Iterator<Object> it = list.iterator();
while (it.hasNext()) { //hasNext()和next()都是迭代器(iterator)下面的方法
Object o = it.next();
System.out.print(o+",");//返回值:张三,二狗子,李四,王五,赵六,安其拉,亚瑟,赵云,
}
}
}

二、Set 集合

Set集合与collection集合使用的方法几乎没啥区别。

2.1、Set集合具备的特点

    无序,不可重复性

     注意:集合中的无序不是指自然顺序,而是指添加元素进去的顺序与元素出来的顺序是不一致的

2.2、List集合与Set集合的区别

相同点:

Set和List一样,也继承于Collection,是集合的一种。

不同点:

Set内部实现是基于Map的,所以Set取值时不保证数据和存入的时候顺序一致,并且不允许空值,不允许重复值。

2.3、实例

 package com.dhb.collection;

 import java.util.HashSet;
import java.util.Set; /**
* @author DSHORE / 2018-5-18
*
*/
public class Demo12 {
public static void main(String[] args) {
Set set=new HashSet();
set.add("王五");
set.add("李四");
set.add("张三");
System.out.println("添加成功了吗:"+set.add("李四"));//返回值:false
System.out.println(set);//返回值:[张三, 李四, 王五] }
}

原创作者:DSHORE

作者主页:http://www.cnblogs.com/dshore123/

原文出自:http://www.cnblogs.com/dshore123/p/9041806.html

欢迎转载,转载务必说明出处。(如果本文对您有帮助,可以点击一下右下角的 推荐,或评论,谢谢!

java基础28 单例集合Collection下的List和Set集合的更多相关文章

  1. java基础27 单例集合Collection及其常用方法

    1.集合 集合是存储对象数据的集合容器 1.1.集合比数组的优势 1.集合可以存储任意类型的数据,数组只能存储同一种数据类型的数据    2.集合的长度是变化的,数组的长度是固定的 1.2.数组:存储 ...

  2. 转载:java基础之单例

    转载:https://blog.csdn.net/goodlixueyong/article/details/51935526 https://www.cnblogs.com/cielosun/p/6 ...

  3. Java基础系列-单例的7种写法

    原创文章,转载请标注出处:https://www.cnblogs.com/V1haoge/p/10755322.html 一.概述 Java中单例有7种写法,这个是在面试中经常被问到的内容,而且有时候 ...

  4. JAVA基础英语单词表(下)

    quantity                     / 'kwɔntiti /                    量,数量 query                             ...

  5. Java设计模式之单例

    一.Java中的单例: 特点: ① 单例类只有一个实例 ② 单例类必须自己创建自己唯一实例 ③ 单例类必须给所有其他对象提供这一实例 二.两种模式: ①懒汉式单例<线程不安全> 在类加载时 ...

  6. Java复习11. 单例编程

    Java复习11. 单例编程 1.最简单的写法,那个方式是线程不安全的 public class Singleton {     private static Singleton instance; ...

  7. 第5节:Java基础 - 必知必会(下)

    第5节:Java基础 - 必知必会(下) 本小节是Java基础篇章的第三小节,主要讲述Java中的Exception与Error,JIT编译器以及值传递与引用传递的知识点. 一.Java中的Excep ...

  8. java基础36 双例集合Map下的HashMap和TreeMap集合

    单例集合体系: ---------| collection  单例集合的根接口--------------| List  如果实现了list接口的集合类,具备的特点:有序,可重复       注:集合 ...

  9. java基础35 双例集合Map及其常用方法

    单例集合体系: ---------| collection  单例集合的根接口--------------| List  如果实现了list接口的集合类,具备的特点:有序,可重复       注:集合 ...

随机推荐

  1. uoj50【UR#3】链式反应

    题解: 令$a(x)$为破坏死光的$EFG$,$f(x)$为方案的$EGF$:$f(x) = x + \int \  \frac{1}{2} f^2(x) a(x) \  dt$; 注意到$f(0)= ...

  2. bzoj4427【Nwerc2015】Cleaning Pipes清理管道

    题目描述 Linköping有一个相当复杂的水资源运输系统.在Linköping周围的出水点有一些水井.这些水通过管道输送到其它地点.每条管道是从某一个水井到城市的某个位置的直线管道. 所有管道在地下 ...

  3. 使用VS2012调试Dump文件

    前一节我讲了怎么设置C++崩溃时生成Dump文件 , 点击 传送门 , 这一节我讲讲怎么使用 VS2012 调试生成的 Dump 文件 , 甚至可以精确到出错的那一行代码上面 ; 1. 生成 Dump ...

  4. Long与long的区别

    Java的数据类型分两种:1.基本类型:long,int,byte,float,double,char2. 对象类型(类): Long,Integer,Byte,Float,Double,Char,S ...

  5. python抓取

    我要抓取奥巴马每周的演讲内容http://www.putclub.com/html/radio/VOA/presidentspeech/index.html 如果手动提取,就需要一个个点进去,再复制保 ...

  6. 前缀、中缀、后缀表达式以及简单计算器的C++实现

    前缀表达式(波兰表达式).中缀表达式.后缀表达式(逆波兰表达式) 介绍 三种表达式都是四则运算的表达方式,用以四则运算表达式求值,即数学表达式的求解. 前缀表达式 前缀表达式是一种没有括号的算术表达式 ...

  7. python学习(23)requests库爬取猫眼电影排行信息

    本文介绍如何结合前面讲解的基本知识,采用requests,正则表达式,cookies结合起来,做一次实战,抓取猫眼电影排名信息. 用requests写一个基本的爬虫 排行信息大致如下图 网址链接为ht ...

  8. P2043 质因子分解

    P2043 质因子分解 题目描述 对N!进行质因子分解. 输入输出格式 输入格式: 输入数据仅有一行包含一个正整数N,N<=10000. 输出格式: 输出数据包含若干行,每行两个正整数p,a,中 ...

  9. Hadoop生态圈-hive五种数据格式比较

    Hadoop生态圈-hive五种数据格式比较 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.

  10. IDEA Mybatis plugin插件破解

    破解文件: 链接:https://pan.baidu.com/s/1J7asfLc5I0RBcoYX3_yNvQ 提取码:kjxv 使用方法: C:\Users\{你的用户名}\.IntelliJId ...