java中的常用集合类整理

一、Set集合

其主要实现类有HashSet、TreeSet存放对象的引用,不允许有重复对象。

实例代码:

public class SetTest {

    public static void main(String[] args) {      

    Set set=new HashSet();       //添加数据       

    set.add("abc");      

    set.add("cba");      

    set.add("abc");//故意重复      

    set.add(123);      

    set.add(true);       

    System.out.println("集合元素个数:"+set.size());       //遍历出集合中每一个元素       

    Iterator it=set.iterator();       

    while(it.hasNext()){         

      System.out.println(it.next());       

    }     

    }  

}

通过java的equals()方法判别。如果有特殊需求须重载equals()方法。

1.HashSet(),调用对象的hashCode()方法,获得哈希码,然后再集合中计算存放对象的位置。通过比较哈希码与equals()方法来判别是否重复。所以,重载了equals()方法同时也要重载hashCode()方法。

相关视频教程推荐:java在线学习

2.TreeSet(),继承ShortedSet接口,能够对集合中对象排序。默认排序方式是自然排序,但该方式只能对实现了Comparable接口的对象排序,java中对Integer、Byte、Double、Character、String等数值型和字符型对象都实现了该接口。

如果有特殊排序,须重载该接口下的compareTo()方法或通过Comparator接口的实现类构造集合。

二、List集合

其主要实现类有LinkedList、ArrayList,前者实现了链表结构,后者可代表大小可变的数组。

List的特点是能够以线性方式储蓄对象,并允许存放重复对象。List能够利用Collections类的静态方法sort排序。sort(List list)自然排序;sort(List listm,Comparator codddmparator)客户化排序。

实例代码:

List:线性集合接口,有序;

ArrayList:动态数组[可变长度的动态数组];

LinkedList:链表结构的集合。

public class ListTest {

   //ArrayList     

   static void testOne(){      

   List list=new ArrayList();       //添加数据       

   list.add("abc");       

   list.add("cba");       

   list.add(123);       

   list.add(0,"fist");       //查看集合长度       

   System.out.println("存放"+list.size()+"个元素");       

   list.remove(0);//删除第一个元素       //查看集合中是否包含cba       

   if(list.contains("cba")){        

   System.out.println("包含元素cba");    

   }        //取出集合中第二个元素       

   System.out.println("第二个元素是:"+list.get(1));        //取出集合中所有元素       

   for (int i = 0; i < list.size(); i++) {         

   System.out.println(list.get(i));      

   }     

   }       //LinkedList      

   static void testTwo(){      

   LinkedList list=new LinkedList();      //添加元素      

   list.add("aaaa");      

   list.add(123123);      

   list.addFirst("1111111");      

   list.addLast("2222222");      

   list.add("33333333");       

   System.out.println("元素个数:"+list.size());      //取出第三个元素      

   System.out.println("第三个元素是:"+list.get(2));       //第一个元素      

   System.out.println("第一个元素:"+list.getFirst());      

   System.out.println("最后一个元素:"+list.getLast());       //删除第一个元素      

   list.removeFirst();       

   for (Object object : list) {        

   System.out.println(object);      

   }     

   }     

   public static void main(String[] args) {     //testOne();     

   testTwo();     

   }  

   }

三、Map集合。

其主要实现类有HashMap、TreeMap。Map对值没有唯一性要求,对键要求唯一,如果加入已有的健,原有的值对象将被覆盖。

HashMap类按照哈希算法来存取键对象,可以重载equals()、hashCode()方法来比较键,但是两者必须一致。TreeMap,可自然排序,也可通过传递Comparator的实现类构造TreeMap。

Map:键值对存储结构的集合,无序。

实例代码:

public class MapTest {

    public static void main(String[] args) {       //实例化一个集合对象       

    Map map=new HashMap();       //添加数据       

    map.put("P01", "zhangSan");       

    map.put("P02", "Lucy");       

    map.put("PSex", "男");       

    map.put("PAge", "39");       

    map.put("PAge", "22");//key,重复会被后面的覆盖        //判断是否有一个key为PSex       

    if(map.containsKey("PSex")){        

      System.out.println("存在");       

    }      

    System.out.println("集合大小:"+map.size());      

    System.out.println("输出key为PAge的值:"+map.get("PAge"));       //遍历出Map集合中所有数据      

    Iterator it=map.keySet().iterator();      

    while(it.hasNext()){      

      String key=it.next().toString();      

      System.out.println("key="+key+",value="+map.get(key));    

    }     

    /*      

    Set set=map.keySet();//取出map中所有的key并封装到set集合中      

    Iterator it=set.iterator();      

    while(it.hasNext()){      

      String key=it.next().toString();      

      System.out.println("key="+key+",value="+map.get(key));    

    }      

    */    

    }  

    }

以上就是java中的常用集合类有哪些的详细内容,希望我们整理的内容能够帮助到大家。

(0)

相关推荐

  • Java集合类知识点总结

    集合:只能存储对象,对象类型可以不一样,长度可变. 常用的接口和类: 1.List接口(有序.可重复):ArrayList类.LinkedList.Vector类 2.Set接口(无序.不能重复):HashSet类.TreeSet类 3.Map接口(键值对.键唯一.值不唯一):HashMap类.Hashtable类.TreeMap类 集合类的循环遍历 1.普通for循环:如 for(int i=0;i<arr.size();i++){-} 2.foreach(增强型for循环):如 for(Ob

  • 基于Java中最常用的集合类框架之HashMap(详解)

    一.HashMap的概述 HashMap可以说是Java中最常用的集合类框架之一,是Java语言中非常典型的数据结构. HashMap是基于哈希表的Map接口实现的,此实现提供所有可选的映射操作.存储的是对的映射,允许多个null值和一个null键.但此类不保证映射的顺序,特别是它不保证该顺序恒久不变. 除了HashMap是非同步以及允许使用null外,HashMap 类与 Hashtable大致相同. 此实现假定哈希函数将元素适当地分布在各桶之间,可为基本操作(get 和 put)提供稳定的性

  • Java集合类的组织结构和继承、实现关系详解

    Collection继承.实现关系如下(说明(I)表示接口, (C)表示Java类,<--表示继承,<<--表示实现): (I)Iterable |<-- (I)Collection |<-- (I)List |<<-- (C)ArrayList |<<-- (C)LinkedList |<<-- (C)Vector |<-- (I)Set |<<-- (C)HashSet |<-- (I)Queue [kju] M

  • java集合类源码分析之Set详解

    Set集合与List一样,都是继承自Collection接口,常用的实现类有HashSet和TreeSet.值得注意的是,HashSet是通过HashMap来实现的而TreeSet是通过TreeMap来实现的,所以HashSet和TreeSet都没有自己的数据结构,具体可以归纳如下: •Set集合中的元素不能重复,即元素唯一 •HashSet按元素的哈希值存储,所以是无序的,并且最多允许一个null对象 •TreeSet按元素的大小存储,所以是有序的,并且不允许null对象 •Set集合没有ge

  • java中的常用集合类整理

    一.Set集合 其主要实现类有HashSet.TreeSet存放对象的引用,不允许有重复对象. 实例代码: public class SetTest { public static void main(String[] args) { Set set=new HashSet(); //添加数据 set.add("abc"); set.add("cba"); set.add("abc");//故意重复 set.add(123); set.add(t

  • java中Hibernate面试知识点整理

    作为常用的框架之一,Hibernate在面试的时候难免会被问到.好在涉及的都是一些理论方面的知识点,比如概念.原理.使用之类的.我们在面试之前可以针对这方面的题目,做一个充足的准备,即使有些人对hibernate框架的了解并不深入.下面我们就hibernate框架中常见的面试题带来介绍. 1. 为什么要使用 hibernate? (1).对JDBC做了轻量级的封装,简化了数据访问层编码. (2).Hibernate是一个ORM框架,开发者可以使用面向对象的思想操作数据库,使用更加方便. (3)

  • Java中的循环笔记整理(必看篇)

    一.循环的类型: 1.for循环 class For{ public static void main(String[] args) { System.out.println("Hello World!"); System.out.println("Hello World!"); System.out.println("Hello World!"); System.out.println("Hello World!"); Sy

  • Java中jqGrid 学习笔记整理——进阶篇(二)

    相关阅读: Java中jqGrid 学习笔记整理--进阶篇(一) 本篇开始正式与后台(java语言)进行数据交互,使用的平台为 JDK:java 1.8.0_71 myEclisp 2015 Stable 2.0 Apache Tomcat-8.0.30 Mysql 5.7 Navicat for mysql 11.2.5(mysql数据库管理工具) 一.数据库部分 1.创建数据库 使用Navicat for mysql创建数据库(使用其他工具或直接使用命令行暂不介绍) 2. 2.创建表 双击打

  • Java中实现多线程关键词整理(总结)

    Java中的Runable,Callable,Future,FutureTask,ExecutorService,Excetor,Excutors,ThreadPoolExcetor在这里对这些关键词,以及它们的用法做一个总结. 首先将它们分个类: Runable,Callable Future,FutureTask ExecutorService,Excetor,Excutors,ThreadPoolExcetor 1. 关于Ranable和Callable 首先Java中创建线程的方法有三种

  • java中Lambda常用场景代码实例

    本文实例为大家分享了java中Lambda常用场景的具体代码,供大家参考,具体内容如下 public class test18 { /** * lambda表达式的常用场景 */ @Test public void test() { List<String> list_one = new ArrayList<>(); list_one.add("NIKE"); list_one.add("Addidas"); /** * 用在匿名内部类里简写

  • Java中List常用操作比for循环更优雅的写法示例

    目录 引言 简单遍历 筛选符合某属性条件的List集合 获取某属性返回新的List集合 获取以某属性为key,其他属性或者对应对象为value的Map集合 以某个属性进行分组的Map集合 其他情况 总结 引言 使用JDK1.8之后,大部分list的操作都可以使用lambda表达式去写,可以让代码更简洁,开发更迅速.以下是我在工作中常用的lambda表达式对list的常用操作,喜欢建议收藏. 以用户表为例,用户实体代码如下: public class User { private Integer

  • Linux中sftp常用命令整理

    SFTP的概念 sftp是Secure File Transfer Protocol的缩写,安全文件传送协议.可以为传输文件提供一种安全的网络的加密方法.sftp 与 ftp 有着几乎一样的语法和功能.SFTP 为 SSH的其中一部分,是一种传输档案至 Blogger 伺服器的安全方式.其实在SSH软件包中,已经包含了一个叫作SFTP(Secure File Transfer Protocol)的安全文件信息传输子系统,SFTP本身没有单独的守护进程,它必须使用sshd守护进程(端口号默认是22

  • JAVA中正则表达式小总结(整理)

    ]js正则表达式基本语法(精粹):  http://www.jb51.net/article/72044.htm 许多语言,包括Perl.PHP.Python.JavaScript和JScript,都支持用正则表达式处理文本,一些文本编辑器用正则表达式实现高级"搜索-替换"功能.所以JAVA语言也不例外.正则表达式已经超出了某种语言或某个系统的局限,成为被人们广为使用的工具,我们完全可以用它来解决实际开发中碰到的一些实际的问题. 在JDK1.3及之前的JDK版本中并没有包含正则表达式的

随机推荐