首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Java集合:什么是Java集合

一、集合的由来 通常,我们的Java程序需要根据程序运行时才知道创建了多少个对象。但若非程序运行,程序开发阶段,我们根本不知道到底需要多少个数量的对象,甚至不知道它的准确类型。...集合便应运而生了。 二、集合是什么? Java集合类存放在java.util包中,是一个用来存放对象的容器。 注意: 1.集合只能存放对象。...比如你存入一个int型数据66放入集合中,其实它是自动转换成Integer类后存入的,Java中每一种基本数据类型都有对应的引用类型。 2.集合存放的都是对象的引用,而非对象本身。...所以我们称集合中的对象就是集合中对象的引用。对象本身还是放在堆内存中。 3.集合可以存放不同类型,不限数量的数据类型。...三、Java集合框架 首先,我们来看一张图 发现一个特点,上述所有的集合类,除了map系列的集合,即左边的集合都实现了Iterator接口。

1.3K20

Java集合:Set集合

TreeSet判断两个对象不相等的方式是两个对象通过equals方法返回false,或者通过CompareTo方法比较没有返回0 TreeSet集合:可以对Set集合中的元素进行排序。是不同步的。...但是TreeSet集合的存储是有序的,即:存储到集合中的元素是按自然顺序存储的。 判断元素唯一性的方式: 根据比较方法的返回值来判断。是0(零)就存入集合,不是0就不存。...因为Set集合是不能有重复的元素,无序。...Java提供了一个Comparable接口,该接口里定义了一个compareTo(Object obj)方法,该方法返回一个整数值,实现了该接口的对象就可以比较大小。...也就是说,当遍历LinkedHashSet集合里元素时,HashSet将会按元素的添加顺序来访问集合里的元素。

1.6K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Java集合:List集合

    List集合 List集合类中元素有序、且可重复,集合中的每个元素都有其对应的顺序索引。 List容器中的元素都对应一个整数型的序号记载其在容器中的位置,可以根据序号存取容器中的元素。...List集合里添加了一些根据索引来操作集合元素的方法 一、ArrayList ArrayList是List接口的典型实现类,本质上,ArrayList是对象引用的一个变长数组。...将指定的元素添加到列表的尾部 **add(int index, E element)**方法,将指定的元素插入此列表的指定位置,如果当前位置有元素,则向右移动当前位于该位置的元素以及所有后续元素(将其索引值加...java.util.vector提供了向量类(Vector)以实现类似动态数组的功能。...java.util包中的其他类中也都有这类方法,以便于用户获取对应的枚举类型。 在Enumeration中封装了有关枚举数据集合的方法。

    1.7K20

    Java集合①)

    集合 集合就是Java中提供的一个容器,可以用来存储多个数据。...集合和数组的区别: 1、数据的长度固定的,集合的长度是可变的; 2、数组中存储的是同一类型的元素,可以存储基本数据类型,集合存储的都是对象; 学习集合的目标: 1、会使用集合存储数据; 2、会遍历集合,...把数据取出来; 3、掌握每种集合的特性; 集合框架学习方式: 1、学习顶层:学习顶层接口/抽象类中的共性方法,所有的子类都可以用; 2、使用底层:底层不是接口/抽象类,需要底层子类创建对象使用; 集合的结构图如下...: Java.util.Collection接口: 所有单列接口的最顶层接口,里面定义了所有单列结合共性的方法; 任意的单列集合都可以使用Collection接口中的方法; Collection接口中的方法...contains(Object obj):判断当前集合中是否包含给定的对象; boolean isEmpty():判断当前集合是否为空; int size():返回集合中元素的个数; Object[]

    65120

    Java集合③)

    List集合 Java.utli.List接口 extends Collection接口 List接口的特点: 1、有序的集合,存储的元素和去除的元素顺序是一致的; 2、有索引,包含了一些带有索引的方法...; 3、允许存储重复元素; List接口中带有索引的方法(特有) void add(int index, E element):在列表的指定位置插入指定元素。...,一定要防止索引的异常 ArrayIndexOutOfBoundsException:数组索引越界异常 IndexOutOfBoundsException:索引越界异常,集合 ArrayList...集合: 存储的结构是数组结构,元素增删慢,查询快 一般用于:查询数据,遍历数据 LinkedList集合: 数据存储的结构是链表结构,方便元素添加,删除 特点: 1、底层是链表; 2、里边包含了大量的首尾元素方法...; 注意: 使用LinkedList集合特有方法,不能使用多态; 常用方法: void addFirst(E e):将指定元素插入此列表的开头; void addLast(E e

    71210

    Java集合(2)---Java集合Collection接口

    1.Collection的定义如下: public interface Collection extends Iterable {} 它是一个接口,是高度抽象出来的集合,它包含了集合的基本操作...List是有序的队列,List中的每一个元素都有一个索引;第一个元素的索引值是0,往后的元素的索引值依次+1。和Set不同,List中允许有重复的元素。 关于API方面。...Set是没有重复元素的集合。...集合可以通过Iterator去遍历集合中的元素。Iterator提供的API接口,包括:是否存在下一个元素、获取下一个元素、删除当前元素。...即,当某一个线程A通过iterator去遍历某集合的过程中,若该集合的内容被其他线程所改变了;那么线程A访问集合时,就会抛出ConcurrentModificationException异常,产生fail-fast

    71400

    Java 集合

    一、集合纲要: 1.集合和数组的区别: 2.Collection集合的方法: 3.常用集合的分类: Collection 接口的接口 对象的集合(单列集合) ├——-List 接口:元素按进入先后有序保存...HashSet 使用hash表(数组)存储元素 │————————└ LinkedHashSet 链表维护元素的插入次序 └ —————-TreeSet 底层实现为二叉树,元素排好序 Map 接口 键值对的集合...(双列集合) ├———Hashtable 接口实现类, 同步, 线程安全 ├———HashMap 接口实现类 ,没有同步, 线程不安全- │—————–├ LinkedHashMap 双向链表和哈希表实现...│—————–└ WeakHashMap ├ ——–TreeMap 红黑树对所有的key进行排序 └———IdentifyHashMap 二、List和Set集合详解: 1.list和set的区别:...Map 接口提供 3 种集合的视图, Map 的内容可以被当作一组 key 集合,一组 value 集合,或者一组 key-value 映射。

    12210

    Java 集合

    Java 集合是一个常用的技术 ,无论是在: 开发使用,还是面试总是高频的提及到~ 正因如此: 本篇是对个人使用集合的, 总结 方法… 不适合初学者,适合面试|复习......Java 集合 集合和数组: 数组声明了它容纳的元素的类型,而集合可以不声明存储Object类型 可以通过泛型进行规范! 数组是静态的,一个数组实例具有固定的大小,一旦创建了就无法改变容量了。...集合: 和数组一样Java中用来存储数据的作用,弥补了数组长度固定的缺点更灵活 Java 集合框架概述 Java 集合可分为 Collection 和 Map 两种体系 Collection接口: 单列数据...0 开使,可储存null; 数值类型会自动装箱; void .add( int,object ); //指定索引位置添加元素 但 不可指定 在超过目前 集合长度; void .forEach(...( int ); //返回指定索引的元素;( 注意这是Object 类型需要类型转换 ); List .sublist(int1,int2); //返回集合 1-2 位置的子集合; Object

    9710

    Java集合②)

    迭(dié)代器 Java.util.Iterator接口:迭代器(对集合进行遍历) 迭代器常用方法 boolean hasNext():检测集合是否还有下一个元素,返回boolea值; E next(...接口中的一个方法iterator():这个方法返回的就是迭代器实现类对象; Iterator iterator():返回在此 collection 的元素上进行迭代的迭代器 迭代器的使用步骤: 1、使用集合中的方法...iterator()获取迭代器实现类对象,使用Iterator接口接收; 2、使用Iterator接口中的方法hasNext()判断还有没有下一个元素; 3、使用Iterator接口中的方法next方法去除集合中的下一个元素...System.out.println(b3);//true String next = iterator.next();//返回集合的下一个值 System.out.println(next);//a...增强for循环: 底层使用的就是迭代器,使用for循环的格式,简化了迭代器的书写; 是jdk1.5之后出现的新特性; 作用:用来遍历集合/数组; 格式: for(集合/数组的数据类型 变量名:集合名/

    34910

    java一种集合_java创建集合

    深入浅出学Java——HashMap 哈希表(hash table) 也叫散列表,是一种非常重要的数据结构,应用场景及其丰富,许多缓存技术(比如memcached)的核心其实就是在内存中维护一张大的哈希表...,本文会对java集合框架中HashMap的实现原理进行讲解,并对JDK7的HashMap源码进行分析。...(其实所谓Map其实就是保存了两个对象之间的映射关系的一种集合) //HashMap的主干数组,可以看到就是一个Entry数组,初始值为空数组{},主干数组的长度一定是2的次幂。...对key值的hashcode进行hash扰乱运算后,再通过和 length-1进行位运算得到最终数组索引位置。...从下图可以我们也能看到这样会保证低位全为1,而扩容后只有一位差异,也就是多出了最左位的1,这样在通过 h&(length-1)的时候,只要h对应的最左边的那一个差异位为0,就能保证得到的新的数组索引和老数组索引一致

    58810

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券