一、集合定义

集合就是讲诺干用途相同、近似的“数据”结合成一个整体
集合从体系上分为三种
1、列表(List):List集合区分元素的顺序,允许包含相同的元素
2、集(set):Set集合不区分元素的顺序,不允许包含相同的元素
3、映射(Map):Map集合保存的“键”-“值”对“键”不能重复,而且一个“键”只能对应一个“值”

  1)list 序列特点

  有序的,可添加重复元素
  ArrayList:顺序结构,容量动态扩充,线程不安全。(不同步)
  LinkedList:离散
  方法:pop:弹出置顶元素
     peek:获取连接的第一个元素
     addFirst:给链表头添加元素
     addLast:给链表尾添加元素
     使用next()获得序列中的下一个元素,使用hasNext()检查序列中是否还有元素。
import java.util.Iterator;
import java.util.LinkedList;
public class s1 { public static void main(String[] args)
{
LinkedList list = new LinkedList();
list.add(100);
list.add("beijing");
list.add(123);
list.add("zhongguo");
for (int i = 0 ; i< list.size();i++)
{
System.out.println(list.get(i));
}
System.out.println("==================");
list.addFirst("lcj"); //给链表头添加元素
list.addLast("haha");//给链表末添加元素
Iterator it = list.iterator();//迭代器
while (it.hasNext())//  2)使用next()获得序列中的下一个元素。3)使用hasNext()检查序列中是否还有元素。
{
System.out.println(it.next());
}
// System.out.println("---------------------------");
// System.out.println(list.peek()); //获取第一个迭代器中第一个元素
System.out.println("------------------");
System.out.println(list.pop()); //弹出置顶元素
System.out.println("弹出之后元素》》");
System.out.println("------------------");
it = list.iterator(); //重新获取迭代器
while (it.hasNext())
{
System.out.println(it.next());
}
}
}

  二、set集合

  没有重复元素的集合

  HashSet特点:顺序结构,无重复元素,允许null值,无序的,线程不安全(不同步)
import java.util.HashSet;
import java.util.Iterator; public class set01 {
public static void main(String[] args)
{
HashSet set = new HashSet();
set.add(100);
set.add("lcj");
set.add(true);
set.add(2.34);
set.add(2.34); //不可添加重复元素:
set.add(null);//可添加null值
//无法使用for循环遍历set集合
// for (int i = 0 ;i<set.size();i++)
// {
// System.out.println(set.);//无法获取列表下标
// }
Iterator it = set.iterator(); //Iterator迭代器
while (it.hasNext()) //hasNext:检查序列中是否还有元素
{
System.out.println(it.next());//使用next()获得序列中的下一个元素
}
}
}

  TreeSet 特点:无重复元素,允许null值,有排序,线程不安全的(不同步)  

import java.util.Iterator;
import java.util.TreeSet; public class set02 {
public static void main(String[] args)
{
TreeSet set = new TreeSet();//TreeSet:有序排序
set.add("chain");
set.add("lcj");
set.add("aw");
set.add("haha");
set.add("beijing");
Iterator it = set.iterator();
while (it.hasNext()) //hasNext:检查序列中是否还有元素
{
System.out.println(it.next()); //使用next()获得序列中的下一个元素
}
}
}
//输出:按照字母排序
//aw
// beijing
//chain
//haha
//lcj

  LinkedSed 特点

  离散结构,通过链表实现,无重复元素,允许Null值,有序,线程不安全的(不同步)
import java.util.Iterator;
import java.util.LinkedHashSet;
public class set03 {
public static void main(String[] args)
{
LinkedHashSet set = new LinkedHashSet();//无序,链表结果
set.add("chain");
set.add("lcj");
set.add("aw");
set.add(null); //允许添加null值
set.add("beijing");
Iterator it = set.iterator(); //遍历结果是有序:即按照写入的顺序排序
while (it.hasNext())
{
System.out.println(it.next());
}
} //chain lcj aw null beijing
}

   三、map集合

  1)Hashtable:无序、基于哈希表的Map接口实现,顺序结构,键和值都不容许是null,值可重复,线程安全,同步,  

import java.util.Hashtable;
import java.util.Iterator;
import java.util.Set; public class hashtable04 {
public static void main(String[] args)
{
Hashtable map = new Hashtable();
map.put(1,"北京");
map.put(2,"武汉");
map.put(3,"天津");
map.put(6,"山西");
// map.put(null,"山西");键不能为null
// map.put(4,null);//值不允许为null
// map.put(null,null);//键值都不允许为null
Set keys = map.keySet(); //返回是一个set集合
Iterator it = keys.iterator(); //迭代器:将keys中元素赋值给it变量
//遍历出来结果是无序的
while (it.hasNext()) ////hasNext:检查序列中是否还有元素
{
Object obj = it.next(); //使用next()获得序列中的下一个元素,即获取键
System.out.println(obj+"="+map.get(obj));//get:获取某一个键对应的值
}
}
}

  2)LinkeHasdMap:离散结构,有序,基于哈希表的Map接口实现,键和值都允许为Null,值可以重复,线程不安全(不同步)

public class hash02 {
public static void main(String[] args)
{
//LinkeHasdMap:离散结构,有序,基于哈希表的Map接口实现,键和值都允许为Null,值可以重复,线程不安全(不同步)
LinkedHashMap map = new LinkedHashMap();
map.put(1,"北京");
map.put(2,"武汉");
map.put(3,"天津");
map.put(6,"山西");
map.put(null,"山西");
map.put(4,null);//键允许为null
map.put(null,null);//键值为null,替换前面的null,山西
Set keys = map.keySet(); //返回是一个set集合
Iterator it = keys.iterator(); //迭代器:将keys中元素赋值给it变量
     //遍历出来结果是有序的
while (it.hasNext()) ////hasNext:检查序列中是否还有元素
{
Object obj = it.next(); //使用next()获得序列中的下一个元素,即获取键
System.out.println(obj+"="+map.get(obj));//get:获取某一个键对应的值 }
}
}

  HashMap:  基于数组实现,无序,键和值可以为null

import java.util.HashMap;
import java.util.Iterator;
import java.util.Set; public class hash01 {
public static void main(String[] args)
{
HashMap map = new HashMap();
map.put(1,"北京");
map.put(2,"武汉");
map.put(3,"天津");
map.put(6,"山西");
map.put(null,"山西");
map.put(4,null);//键允许为null
map.put(null,null);//键值为null,替换前面的null,山西
Set keys = map.keySet(); //返回是一个set集合
Iterator it = keys.iterator(); //迭代器:将keys中元素赋值给it变量
//遍历出来结果是无序的
while (it.hasNext()) ////hasNext:检查序列中是否还有元素
{
Object obj = it.next(); //使用next()获得序列中的下一个元素,即获取键
System.out.println(obj+"="+map.get(obj));//get:获取某一个键对应的值
}
}
}

  3)TreeMap

  基于红黑树(Red-Back tree)的NavigableMap实现,该映射根据其键的自然顺序进行排序,或者根据创建映射时提供的Comparator进行排序,具体取决于使用的构造方法

  特点:

  键不允许为null,并且数据类型一致,值允许是null

  实现自然排序

  线程不安全(不同步)

import java.util.Iterator;
import java.util.Set;
import java.util.TreeMap; /**
* Created by luochengjia on 2016/7/15.
*/
public class treemap05 {
public static void main(String[] agrs)
{
TreeMap map = new TreeMap();
map.put(1,"北京");
map.put(2,"武汉");
map.put(3,"天津"); //数据类型为:int
// map.put(null,"天津"); 键不允许为null
map.put(6,"山西");
// map.put("6","山西"); 键数据类型一致:字符串 String
map.put(6,null);
Set keys = map.keySet(); //返回是一个set集合
Iterator it = keys.iterator(); //迭代器:将keys中元素赋值给it变量
//遍历出来结果是按照输入时顺序进行排序
while (it.hasNext()) ////hasNext:检查序列中是否还有元素
{
Object obj = it.next(); //使用next()获得序列中的下一个元素,即获取键
System.out.println(obj+"="+map.get(obj));//get:获取某一个键对应的值
}
}
}

  

  

  

java_list,set,map集合的更多相关文章

  1. Java版本:识别Json字符串并分隔成Map集合

    前言: 最近又看了点Java的知识,于是想着把CYQ.Data V5迁移到Java版本. 过程发现坑很多,理论上看大部分很相似,实践上代码写起来发现大部分都要重新思考方案. 遇到的C#转Java的一些 ...

  2. Java常用的几种集合, Map集合,Set集合,List集合

    Java中  Object是所有类的根 Java集合常用的集合List集合.Set集合.Map集合 Map接口常用的一些方法 size() 获取集合中名值对的数量 put(key k, value v ...

  3. Map集合

    1:Map (1)将键映射到值的对象. 一个映射不能包含重复的键:每个键最多只能映射到一个值. 键值对的方式存在 (2)Map和Collection的区别? A:Map 存储的是键值对形式的元素,键唯 ...

  4. MyBatis的一系列问题的处理(遍历Map集合和智能标签和属性和字段不一样的解决办法 和sql片段)(三)

    一.字段名与属性名(数据库的名字)不一样怎么办? 方案一:在小配置中配置一个resultMapper <!--方案一:resultMapper 字段名与属性名不一致 --> <res ...

  5. Map集合及与Collection的区别、HashMap和HashTable的区别、Collections、

    特点:将键映射到值的对象,一个映射不能包含重复的键,每个键最多只能映射到一个值. Map集合和Collection集合的区别 Map集合:成对出现 (情侣)                       ...

  6. java://Comparator、Comparable的用法(按照要求将map集合的键值对进行顺序输出)

    import java.util.*; public class Person implements Comparable<Person>//使Person的属性具有比较性 { priva ...

  7. Java集合类学习笔记(Map集合)

    Map用于保存具有映射关系的数据,因此Map集合里保存着两组数据,一组用于保存Map的key,一组用于保存key所对应的value. Map的key不允许重复. HashMap和Hashtable都是 ...

  8. java学习第18天(map集合)

    Map集合是将键映射到值的对象.一个映射不能包含重复的键:每个键最多只能映射到一个值. 存储的是键值对形式的元素,键唯一,值可以重复,有点类似于数据库中的主键加数据.主要功能有: A:添加功能 put ...

  9. Map集合 总结

    (本人第一次写博客,部分内容有参照李刚老师的疯狂java系列图书,如有遗漏错误,请多指教,谢谢.) Java的集合类可分为Set.List.Map.Queue,其中Set.List.Queue都有共同 ...

随机推荐

  1. hdu 2030

    PS:原本这道题就空了好久...今天才去查了下汉字机内码... 然后才知道了. 1—— 一个汉字在字符串中是以两个负的字符形式存储,所以本题只要把字符串中负字符的个数找出来,再 除以2 就OK了. 2 ...

  2. leetcode 238 Product of Array Except Self

    这题看似简单,不过两个要求很有意思: 1.不准用除法:最开始我想到的做法是全部乘起来,一项项除,可是中间要是有个0,这做法死得很惨. 2.空间复杂度O(1):题目说明了返回的那个数组不算进复杂度分析里 ...

  3. leetcode 239 Sliding Window Maximum

    这题是典型的堆排序算法,只是比一般的堆算法多了删除的操作,有两件事需要做: 1 用一个hash表存储从输入数组索引到堆数组(用于实现堆的那个数组)所以的映射,以便在需要删除一个元素的时候能迅速定位到堆 ...

  4. Python网络编程03----Python3.*中socketserver

    socketserver(在Python2.*中的是SocketServer模块)是标准库中一个高级别的模块.用于简化网络客户与服务器的实现(在前面使用socket的过程中,我们先设置了socket的 ...

  5. 学习笔记:APP切图那点事儿–详细介绍android和ios平台

    学习笔记:APP切图那点事儿–详细介绍android和ios平台 转载自:http://www.woofeng.cn/articles/168.html   版权归原作者所有 作者:亚茹有李 原文地址 ...

  6. Oracle查看表结构的几种方法(转后加工)

    1. DESCRIBE 命令使用方法如下:SQL> describe WX_ADVANCEUP (WX_ADVANCEUP为表名)显示的结果如下: 名称                     ...

  7. min-height最小高度的实现(兼容IE6、IE7、FF)(解决IE6不兼容min-height)

    <!doctype html><html> <head> <meta charset="UTF-8"> <meta name= ...

  8. 冒泡排序(python版)

    实现源码 def bubble(array): flag = len(array)- : iter = for i in range(flag): ]: array[i], array[i+]= ar ...

  9. linux信号处理及libcurl的坑

    前言:     最近有个项目, 需要访问第三方服务. 该服务是通过http的形式访问的, 为了安全和加密, 对方提供了一个加密用的C/C++库, 用于对参数进行处理.  鉴于此, 选用了C/C++语言 ...

  10. ros与下位机通信常用的c++ boost串口应用--22

    摘要: 原创博客:转载请表明出处:http://www.cnblogs.com/zxouxuewei/ 一.首先移植c++ boost 库: 1. 先去 Boost官网 下载最新的Boost版本, 我 ...