【java】java集合list与set、map集合的区别、用法详解

一、前言

Java集合的主要分为三种类型:

  1、Set(集)  2、List(列表)  3、Map(映射)    

java集合的接口:

  1、java集合由两个接口实现,分别为Collection (list、set)和 Map(map),和一个中立的接口 Iterator

  2、Collection 与Map接口区别:

    a、容器内每个为之所存储的元素个数不同。

    b、Collection类型者,每个位置只有一个元素。

    c、Map类型者,持有key-value pair,像个小型数据库

  3、各自旗下的子类关系

   Collection

   --List 将以特定次序存储元素。所以取出来的顺序可能和放入顺序不同。

      --ArrayList / LinkedList / Vector

   --Set 不能含有重复的元素

     --HashSet / TreeSet
   Map
   --HashMap
   --HashTable
   --TreeMap

 4、中立接口Iterator

   a、包含以下方法

     hasNext():判断集合中元素是否遍历完毕,如果没有,就返回true   

     next() :返回下一个元素   

     remove():从集合中删除上一个有next()方法返回的元素。  

   b、与Collection、Map的关系

     list与set继承至Collection,map集合继承至Map;Collection与Map接口实现了Iterator

     换句话说,无论是list,set还是map,都可以通过Iterator 进行遍历。所以我称他是中立的接口;

 5、其他特征

    a、List,Set,Map将持有对象一律视为Object型别。

    b、Collection、List、Set、Map都是接口,不能实例化。继承自它们的 ArrayList, Vector, HashTable, HashMap才能被实例化

    c、vector容器确切知道它所持有的对象隶属什么型别。vector不进行边界检查

    d、关于Iterator() 和toArray() 方法都用于集合的所有的元素,前者返回一个Iterator对象,后者返回一个包含集合中所有元素的数组。

二、Collection接口

常用方法:

 booleanadd(Object o)      :向集合中加入一个对象的引用    

 voidclear():删除集合中所有的对象,即不再持有这些对象的引用  

 booleanisEmpty()    :判断集合是否为空  

 booleancontains(Object o) : 判断集合中是否持有特定对象的引用  

 Iterartoriterator()  :返回一个Iterator对象,可以用来遍历集合中的元素

 booleanremove(Object o) :从集合中删除一个对象的引用  

 intsize()       :返回集合中元素的数目  

 Object[]toArray()    : 返回一个数组,该数组中包括集合中的所有元素

集合详解:    

 1、list集合

 使用方法

[java] view plain copy
 print?
  1. <span style="font-family:Verdana;font-size:18px;">package tests;  
  2.   
  3. import java.util.ArrayList;  
  4. import java.util.Collections;  
  5. import java.util.Iterator;  
  6. import java.util.List;  
  7.   
  8. public class test {  
  9.     /** 
  10.      * 1.list中添加,获取,删除元素; 
  11.      * 2.遍历取值 
  12.      * 3.list中是否包含某个元素; 
  13.      * 4.list中根据索引将元素数值改变(替换); 
  14.      * 5.list中查看(判断)元素的索引; 
  15.      * 6.根据元素索引位置进行的判断; 
  16.      * 7.利用list中索引位置重新生成一个新的list(截取集合); 
  17.      * 8.对比两个list中的所有元素; 
  18.      * 9.判断list是否为空; 
  19.      * 10.去重复; 
  20.      * 11.返回Iterator集合对象;将集合转换为字符串;将集合转换为数组; 
  21.      */  
  22.     public static void main(String[] args) {  
  23.         /** 
  24.          * 1.list中添加,获取,删除元素; 
  25.          * 添加方法:add(e);获取方法是:get(index); 
  26.          * 删除方法:remove(index); 按照索引删除;remove(Object o); 按照元素内容删除; 
  27.          */  
  28.         List<String> person=new ArrayList<>();  
  29.         person.add("jackie");   //索引为0  //.add(e)  
  30.         person.add("peter");    //索引为1  
  31.         person.add("annie");    //索引为2  
  32.         person.add("martin");   //索引为3  
  33.         person.add("marry");    //索引为4  
  34.            
  35.         person.remove(3);   //.remove(index)  
  36.         person.remove("marry");     //.remove(Object o)  
  37.            
  38.         String per="";  
  39.         per=person.get(1);  
  40.         System.out.println(per);    //.get(index)   //peter  
  41.           
  42.         /** 
  43.          * 2.list的遍历取值 
  44.          */  
  45.         //第一种 对于ArrayList来说速度比较快, 用for循环, 以size为条件遍历:  
  46.         for (int i = 0; i < person.size(); i++) {     
  47.             System.out.println(person.get(i));  //.get(index)  
  48.         }  
  49.         //第二种 超级for循环遍历   推荐  
  50.         for (String p:person) {  
  51.             System.out.println(p);    
  52.         }  
  53.         //第三种 集合类的通用遍历方式, 从很早的版本就有, 用迭代器迭代  
  54.         Iterator<String> it = person.iterator();  
  55.         while(it.hasNext()) {  
  56.           System.out.println(it.next());  
  57.         }  
  58.           
  59.         /** 
  60.          * 3.list中是否包含某个元素; 
  61.          * contains(Object o); 返回true或者false 
  62.          */  
  63.         List<String> fruits=new ArrayList<>();  
  64.         fruits.add("苹果");  
  65.         fruits.add("香蕉");  
  66.         fruits.add("桃子");  
  67.          
  68.         String appleString="苹果";  
  69.         //true or false  
  70.         System.out.println("fruits中是否包含苹果:"+fruits.contains(appleString));   
  71.   
  72.         if (fruits.contains(appleString)) {   //应用场景  
  73.             System.out.println("我喜欢吃苹果");  
  74.         }else {  
  75.             System.out.println("我不开心");  
  76.         }  
  77.           
  78.         /** 
  79.          * 4.list中根据索引将元素数值改变(替换); 
  80.          * 注意 .set(index, element); 和 .add(index, element); 的不同; 
  81.          */  
  82.         String a="白龙马", b="沙和尚", c="八戒", d="唐僧", e="悟空";  
  83.         List<String> people=new ArrayList<>();  
  84.         people.add(a);  
  85.         people.add(b);  
  86.         people.add(c);  
  87.         //将d唐僧放到list中索引为0的位置,替换a白龙马  
  88.         people.set(0, d);   //.set(index, element);  
  89.         //将e悟空放到list中索引为1的位置,原来位置的b沙和尚后移一位  
  90.         people.add(1, e);   //.add(index, element);  
  91.          
  92.         System.out.println(people.get(0)); //唐僧  
  93.         System.out.println(people.get(1)); //悟空  
  94.            
  95.         /** 
  96.          * 5.list中查看(判断)元素的索引; 
  97.          * 注意:.indexOf(); 和  lastIndexOf()的不同; 
  98.          */  
  99.         List<String> names=new ArrayList<>();  
  100.         names.add("刘备");    //索引为0  
  101.         names.add("关羽");    //索引为1  
  102.         names.add("张飞");    //索引为2  
  103.         names.add("刘备");    //索引为3  
  104.         names.add("张飞");    //索引为4  
  105.          
  106.         System.out.println(names.indexOf("刘备"));   // 0   
  107.         System.out.println(names.lastIndexOf("刘备")); // 3  
  108.         System.out.println(names.indexOf("张飞"));  //2   
  109.         System.out.println(names.lastIndexOf("张飞")); //4  
  110.           
  111.         /** 
  112.          * 6.根据元素索引位置进行的判断; 
  113.          */  
  114.         if (names.indexOf("刘备")==0) {  
  115.             System.out.println("刘备在这里");  
  116.         }else if (names.lastIndexOf("刘备")==3) {  
  117.             System.out.println("刘备在那里");  
  118.         }else {  
  119.             System.out.println("刘备到底在哪里?");  
  120.         }  
  121.           
  122.         /** 
  123.          * 7.利用list中索引位置重新生成一个新的list); 
  124.          * 方法: .subList(fromIndex, toIndex); 截取集合  
  125.          * 方法: .size() ; 该方法得到list中的元素数的和 
  126.          */  
  127.         List<String> phone=new ArrayList<>();  
  128.         phone.add("三星");    //索引为0  
  129.         phone.add("苹果");    //索引为1  
  130.         phone.add("锤子");    //索引为2  
  131.         phone.add("华为");    //索引为3  
  132.         phone.add("小米");    //索引为4  
  133.           
  134.         for(String pho:phone){   //原list进行遍历  
  135.             System.out.println(pho);  
  136.         }  
  137.         //生成新list  
  138.         //利用索引1-4的对象重新生成一个list,但是不包含索引为4的元素,4-1=3  
  139.         phone=phone.subList(14);  //.subList(fromIndex, toIndex)    
  140.         for (int i = 0; i < phone.size(); i++) {   
  141.             //新的list包含的元素是苹果  新的list包含的元素是锤子  新的list包含的元素是华为  
  142.             System.out.println("新的list包含的元素是"+phone.get(i));   
  143.         }  
  144.           
  145.         /** 
  146.          * 8.对比两个list中的所有元素; 
  147.          * 两个相等对象的equals方法一定为true, 但两个hashcode相等的对象不一定是相等的对象 
  148.          */  
  149.         if (person.equals(fruits)) {  
  150.             System.out.println("两个list中的所有元素相同");  
  151.         }else {  
  152.             System.out.println("两个list中的所有元素不一样");  
  153.         }  
  154.         if (person.hashCode()==fruits.hashCode()) {  
  155.             System.out.println("我们相同");  
  156.         }else {  
  157.             System.out.println("我们不一样");  
  158.         }  
  159.           
  160.         /** 
  161.          * 9.判断list是否为空; 
  162.          * 空则返回true,非空则返回false 
  163.          */  
  164.         if (person.isEmpty()) {  
  165.             System.out.println("空的");  
  166.         }else {  
  167.             System.out.println("不是空的");  
  168.         }  
  169.           
  170.         /** 
  171.          * 10.去重复 
  172.          */  
  173.         List<String> lst1=new ArrayList<>();  
  174.         lst1.add("aa");  
  175.         lst1.add("dd");  
  176.         lst1.add("ss");  
  177.         lst1.add("aa");  
  178.         lst1.add("ss");  
  179.   
  180.         //方法 1.  
  181.         for (int i = 0; i <lst1.size()-1; i++) {  
  182.             for (int j = lst1.size()-1; j >i; j--) {  
  183.                 if (lst1.get(j).equals(lst1.get(i))) {  
  184.                     lst1.remove(j);  
  185.                 }  
  186.             }  
  187.         }  
  188.         System.out.println(lst1);  
  189.            
  190.         //方法 2.  
  191.         List<String> lst2=new ArrayList<>();  
  192.         for (String s:lst1) {  
  193.             if (Collections.frequency(lst2, s)<1) {  
  194.                 lst2.add(s);  
  195.             }  
  196.         }  
  197.         System.out.println(lst2);  
  198.           
  199.         /** 
  200.          * 11.其他常用方法 
  201.          * 返回Iterator集合对象;将集合转换为字符串;将集合转换为数组; 
  202.          */  
  203.         System.out.println("将集合转换为数组:"+person.toArray());  
  204.         System.out.println("将集合转换为字符串:"+person.toString());  
  205.         System.out.println("返回Iterator集合对象:"+person.iterator());  
  206.     }  
  207. }  
  208. </span>  
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值