这个代码这样写是没有问题的,但是语句却很长,不易于阅读,网上查阅资料后发现这样一段话
,因此ArrayList集合不适合删除和插入,而适合查找和遍历操作; 5、ArrayList集合长度自动增长原理 ArrayList集合不需要在定义时指定数组的长度,当所要存储的元素超过ArrayList...(linkedList); System.out.println("====================="); 2、将指定的元素插入到集合的末尾: //2、将指定的元素插入到集合的末尾...("====================="); 5、获取集合的最后一个元素: //5、获取集合的最后一个元素 System.out.println("获取集合的最后一个元素为...//6、移除并返回集合的第一个元素 System.out.println("所移除的集合的第一个元素为"+linkedList.removeFirst()); System.out.println...: //7、移除并返回集合的最后一个元素 System.out.println("所移除的集合的最后一个元素为"+linkedList.removeLast());
java集合概述 Java 集合可分为 Collection 和 Map 两种体系 Collection接口:单列数据,定义了存取一组对象的方法的集合 List:元素有序(指的是存储时,与存放顺序保持一致...正常情况下,大多数的Java程序员使用ArrayList而不是Vector,因为同步完全可以由程序员自己来控制。Vector每次扩容请求其大小的2倍空间,而ArrayList是1.5倍。...集合中,则添加操作失败。...HashSet 按 Hash 算法来存储集合中的元素,因此具有很好的存取、查找、删除性能。...当需要把一个对象放入 TreeSet 中,重写该对象对应的 equals() 方法时,应保证该方法与 compareTo(Object obj) 方法有一致的结果:如果两个对象通过equals() 方法比较返回
一、Java中的集合 集合接口 集合框架定义了一些接口。...---- 集合实现类(集合类) Java提供了一套实现了Collection接口的标准集合类。其中一些是具体类,这些类可以直接拿来使用,而另外一些是抽象类,提供了接口的部分实现。...在前面的教程中已经讨论通过java.util包中定义的类,如下所示: 类名称 类描述 Vector 该类和ArrayList非常相似,但是该类是同步的,可以用在多线程的情况,该类允许设置默认的增长长度...Hashtable Hashtable 是 Dictionary(字典) 类的子类,位于 java.util 包中。...BitSet中数组大小会随需要增加。 迭代器 通常情况下,你会希望遍历一个集合中的元素。例如,显示集合中的每个元素。
1、Set接口简介 一个不包含重复元素的集合; 此接口没有索引,没有带索引的方法; set接口跟Collection方法基本一致,主要研究其实现类; 2、HashSet 简介 此类实现set接口,由哈希表...(实际上是一个HashMap实例)支持; 它不保证set的迭代顺序,特别是不保证该顺序恒久不变; 允许使用null元素; 此实现不是同步的(多线程,速度快); 特点 一个不包含重复元素的集合; 此接口没有索引...,没有带索引的方法; 无序的集合,存取元素的顺序可能不一致; 底层是一个HashMap结构(查询速度快); //多态方式实现HashSet Set set...基本思路: 当set调用add方法的时候,会将当前所要存储的元素的哈希值在集合中查找,若未查找到,则存储集合,若查找到则会调用equals方法,与集合中已经存在的相同哈希值的元素进行比较,若返回true...则不再将所要存储的元素存储到集合中,若返回false则将所要存储的元素存储到集合中。
容量可以变,并且不用开发者操心 1.2 集合架构 Java中集合的【总接口】Collection。...); 删除集合中的指定元素 boolean removeAll(Collection<?...obj); 判断指定元素在当前集合中是否存在 boolean containsAll(Collection c); 判断集合c是不是当前集合的子集合 以下是代码的实现: 注意导包,之前的部分代码也需要导包 就是这个: import java.util.ArrayList; import java.util.Collection...extends E> c); 在指定的下标位置,添加指定的集合,集合要求同上一个addAll方法 删: void clear(); 清空整个集合 remove(Object obj); 删除集合中的指定元素
①Properties集合是唯一一个跟IO结合的集合; ②可以使用Properties的store方法,把集合的临时数据,持久化地写入到硬盘中; ③可以使用Properties的load方法,把硬盘中保存的文件...,添加数据; ②创建字节输出流/字符输出流对象,构造方法中绑定输出的目的地; ③使用Properties中的store方法,可以将内存中的集合的临时数据写入到硬盘中存储; ④释放资源; 4、代码演示 代码...: package study.io; import java.io.FileWriter; import java.io.IOException; import java.util.Properties...store方法,可以将内存中的集合的临时数据写入到硬盘中存储; properties.store(fileWriter,""); //④释放资源; fileWriter.close...; ③遍历Properties集合; 4、注意 ①存储键值对的文件中,键与值默认的连接符号可以使用=,空格(或其他符号); ②存储键值对的文件中,可以使用#进行注释,被注释的键值对不对再被读取; ③存储键值对的文件中
集合中的对象排序需求还是比較常见的。当然我们能够重写equals方法,循环比較;同一时候Java为我们提供了更易使用的APIs。...当须要排序的集合或数组不是单纯的数字型时,通常能够使用Comparator或Comparable。以简单的方式实现对象排序或自己定义排序。...import java.util.Arrays;public class ComparableUser implements Comparable { private String id; private...; import java.util.Comparator; public class UserComparator implements Comparator { public int compare...假设一个类实现了Comparable接口,则表明这个类的对象之间是能够相互比較的,这个类对象组成的集合就能够直接使用sort方法排序。 而Comparator能够看成一种算法的实现。
集合概述 集合到底是什么呢? 集合:集合是java中提供的一种容器,可以用来存储多个数据。 集合和数组既然都是容器,它们有啥区别呢? 数组的长度是固定的。集合的长度是可变的。...集合按照其存储结构可以分为两大类,分别是单列集合java.util.Collection和双列集合java.util.Map本文主要讲Collection集合,后续再补充Map集合。...集合本身是一个工具,它存放在java.util包中。在Collection接口定义着单列集合框架中最最共性的内容。...public boolean remove(E e): 把给定的对象在当前集合中删除。 public boolean contains(E e): 判断当前集合中是否包含给定的对象。...public Object[] toArray(): 把集合中的元素,存储到数组中。
2、集合的框架 二、Collection集合的常用方法 1、将给定的对象添加到指定的集合中 方法: boolean add(E e) 说明: 将给定的对象添加到指定的集合中,一般返回的都是true,不用理会...; 使用: // 1、将给定的对象添加到指定的集合中 Collection collection = new ArrayList(); collection.add...小兰"); collection.add("小李"); System.out.println(collection);//[小明,小兰,小李] 2、将给定的对象从指定的集合中删除...boolean remove(Object o) 说明: 若存在指定的元素,则删除成功,返回true;若不存在指定的元素,则删除失败,返回false; 使用: // 2、将给定的对象从指定的集合中删除...);//[] 4、判断给定的对象是否在指定的集合中 方法: boolean contains(Object o) 使用: // 4、判断给定的对象是否在指定的集合中 System.out.println
java中数组: 数组在Java里是一种特殊类型,有别于普通的“类的实例”的对象。...但实际数组也是一种对象类型,int[]a = new int[5] a是在java栈中分配的引用变量,类型是int[] 数组类型,指向在堆里面地址连续的实际数组对象。...在内存中,数组存储在连续的区域内部,因为数组中每个元素的类型相同,则占用的内存大小也一致,所以在访问数组中的元素时可以直接根据数组在内存中的起始位置以及下标来计算元素的位置,因此数组的访问速度很高。...2》同一个数组只能存储同一种数据类型(基本类型/引用类型).集合不考虑泛型可以存储多种数据类型,集合是存储对象的,所以基本类型不能放入集合,可以使用基本类型的包装类型。...数组和集合之间进行转化: toArray():将集合转化为数组。 Arrays.asList():将数组转化为集合. 集合的体系结构 List、Set、Map是这个集合体系中最主要的三个接口。
1.Collection接口 Collection是最基本的集合接口,声明了适用于JAVA(List和Set)集合的通用方法 collection接口的方法:add()、clear()、iterator...3.List(列表) List的特征是其元素以线性方式存储,集合中可以存放重复对象。...Map没有继承于Collection接口,从Map集合中检索元素时候,只要给出键对象,就会返回对应的值对象。...remove(键):删除元素,一次删一对 获取map集合中的所有的数据: 1.keySet():获取map中所有的键,方法返回set集合,因为map中的键是惟一的。...所以取出来的顺序可能和放入顺序不同。
如果把Map集合里的所有value放在一起来看,它们又类似于一个List,元素可以重复,每个元素可以根据索引来找,只是Map中的索引不再是整数值,而是以另一个对象作为索引。...(Object value):查询Map中是否包含一个或多个value; Set entrySet():返回map中包含的键值对所组成的Set集合,每个集合都是Map.Entry对象。...Object put(Object key,Object value):添加一个键值对,如果集合中的key重复,则覆盖原来的键值对; void putAll(Map m):将Map中的键值对复制到本Map...不能修改集合中的key,否则程序再也无法准确访问到Map中被修改过的key。...",70); map.put("java",71); System.out.println(map);//{java=71, 语文=90, 语文=89} 前面是两个对象虽然通过
1.2 Java中的实现 上一篇,阐述了队列的实现结构,通过图片的形式让大家有了更进一步的了解。 接下来,我,我们来看看队列在Java具体是如何成仙了,来看下Queue的代码!!!...在Java中,ArrayDeque、LinkedList、PriorityQueue等类实现了Queue接口,模拟了队列的数据结构。...这就是所谓的“优先级队列”---元素按照任意的顺序插入,却总是按照顺序进行输出;每次从优先队列中取出来的元素要么是最大值,要么是最小值。...: PriorityQueue成员变量和构造方法: public class PriorityQueue extends AbstractQueue implements java.io.Serializable...所以,我们在代码中可以看到PriorityQueue最底层数据结构就是数组。
当hash表的负载因子达到指定负载极限时,hash表会自动成倍地增加容量,并将原有的对象重新分配,放入新的桶中。HashSet、HashMap、Hashtable默认的负载极限是0.75。...当向HashSet中添加可变对象时,必须十分小心。如果修改HashSet集合中的对象,有可能导致该对象与集合中的其他对象相等,从而导致HashSet无法准确访问该对象。...采用自然排序,则返回null; Object first():返回集合中的第一个元素; Object last():返回集合中的最后一个元素; Object lower(Object e):返回指定元素之前的元素...:"+nums.first());//集合中的第一个元素:-4 System.out.println("集合中的最后一个元素:"+nums.last());//集合中的最后一个元素:15...当把一个对象添加进集合时,集合调用该对象的CompareTo(Object obj)方法与容器中的其他对象比较大小,然后根据红黑树结构中找到它的存储位置。如果两个对象相等则新对象无法加入到集合中。
1.2 ArrayDeque源码(基于JDK1.7.0_45) 值得一提的是,Java中有一个类叫做Stack,该类实现了栈结构。...但是,Java已经不提倡Stack来实现栈结构,而是建议使用ArrayDeque类; 来自Stack类描述: A more complete and consistent set of LIFO stack...可设置队列大小的构造函数: public ArrayDeque(int numElements) { allocateElements(numElements); } //带集合的构造函数...:移除数组中head指针所指向的元素; public E removeFirst() { E x = pollFirst(); //如果队列中没有元素,则抛出异常...集合方法,又有Deque集合方法。
JAVA中集合的遍历的一种方法时集合转数组遍历,也是就调用Collection中的toArray()....Student(“uj”,13)); c.add(new Student(“tj”,15)); c.add(new Student(“cj”,14)); Object[]ob= c.toArray();//将集合转换为数组...Student)ob[i]; System.out.println(s.getName()+”…”+s.getAge()); } } 运行结果: kj…12 uj…13 tj…15 cj…14 需要注意的是集合转数组进行遍历的时候调用...当集合所装的类型为对象时,不能直接通过调用对象类的方法拿到对象参数,因为就算存储的是Student对象,已近提升成为了Object。多态的弊端就是,不能使用子类的属性和方法。
集合类中主要有几种接口? Collection:是集合List、Set、Queue的最基本的接口。 Iterator:迭代器,可以通过迭代器遍历集合中的内容。 Map:是映射表的基础接口。...集合中泛型的优点 保证了类型的安全性:泛型约束了变量的类型,保证了类型的安全性。 避免了不必要得装箱、拆箱的操作,提高了程序的性能:泛型变量固定了类型,在使用时就已经知道是值类型还是引用类型。...数据总是从Channel通道中读取到Buffer缓冲区中,或者从Buffer缓冲区中写入到Channel通道中。Selector监视器则用于监听多个通道的事件,如:连接打开、数据到达等。...Java中的流 按照流的方向: 输入流 输出流 按照实现功能: 节点流 处理流 按照处理数据的单位: 字节流 字符流 ---- 20....什么是Java序列化?如何实现Java序列化? 序列化: 是一种用来处理对象流的机制,而所谓的对象流就是将对象的内容进行流化,可以对流化后的对象进行对写操作,也可将流化后的对象传输于网路之间。
一、此异常主要在以下两种情况下发生 1、当快速失败迭代器在同一个线程中迭代集合时,集合使用集合的方法而非迭代器方法修改。...示例: package com.renzhikeji.demo; import java.util.ArrayList; import java.util.Iterator; import java.util.List...二、处理这种情况有两种方法 1、在迭代期间不允许对底层集合进行修改。 (1)使用同步机制防止其他线程并发访问集合。...错误示例: package com.renzhikeji.demo; import java.util.ArrayList; import java.util.Iterator; import java.util.List...iterator.remove(); } } System.out.println(list); } } 2、不要使用快速失败迭代器,而应使用并发集合中的快速安全
Queue Java 中的 这个 Queue 接口稍微有点坑,一般来说队列的语义都是先进先出(FIFO)的。...答:Java 6 以前。。。因为 ArrayDeque 在 Java 6 之后才有的。。 那最后一个问题,就是关于 Stack 了。...那在 Java 中是怎么实现栈的呢? 虽然 Java 中有 Stack 这个类,但是呢,官方文档都说不让用了!
领取专属 10元无门槛券
手把手带您无忧上云