当前位置: 首页 > news >正文

网站规划与建设 pptwordpress 进入

网站规划与建设 ppt,wordpress 进入,discuz网站模板下载,云南省火电建设公司网站Java 集合框架可以分为两条大的支线#xff1a; ①、Collection#xff0c;主要由 List、Set、Queue 组成#xff1a; List 代表有序、可重复的集合#xff0c;典型代表就是封装了动态数组的 ArrayList 和封装了链表的 LinkedList#xff1b;Set 代表无序、不可重复的集… Java 集合框架可以分为两条大的支线 ①、Collection主要由 List、Set、Queue 组成 List 代表有序、可重复的集合典型代表就是封装了动态数组的 ArrayList 和封装了链表的 LinkedListSet 代表无序、不可重复的集合典型代表就是 HashSet 和 TreeSetQueue 代表队列典型代表就是双端队列 ​​​​​​​ArrayDeque以及优先级队列  PriorityQueue。 ②、Map代表键值对的集合典型代表就是HashMap 一、List List 的特点是存取有序可以存放重复的元素可以用下标对元素进行操作。 1ArrayList 先来一段 ArrayList 的增删改查学会用。 // 创建一个集合 ArrayListString list new ArrayListString(); // 添加元素 list. Add(aa); list. Add(bb); list. Add(ccc);// 遍历集合 for 循环 for (int i 0; i list.size(); i) {String s list. Get(i);System.out.println(s); } // 遍历集合 for each for (String s : list) {System.out.println(s); }// 删除元素 list.remove(1); // 遍历集合 for (String s : list) {System.out.println(s); }// 修改元素 list. Set(1, aaa); // 遍历集合 for (String s : list) {System.out.println(s); } 简单介绍一下 ArrayList 的特征 ArrayList 是由数组实现的支持随机存取也就是可以通过下标直接存取元素从尾部插入和删除元素会比较快捷从中间插入和删除元素会比较低效因为涉及到数组元素的复制和移动如果内部数组的容量不足时会自动扩容因此当元素非常庞大的时候效率会比较低。 (2) LinkedList 同样先来一段 LinkedList 的增删改查和 ArrayList 几乎没什么差别。 // 创建一个集合 LinkedListString list new LinkedListString(); // 添加元素 list. Add(aa); list. Add(bb); list. Add(ccc);// 遍历集合 for 循环 for (int i 0; i list.size(); i) {String s list.get(i);System.out.println(s); } // 遍历集合 for each for (String s : list) {System.out.println(s); }// 删除元素 list.remove(1); // 遍历集合 for (String s : list) {System.out.println(s); }// 修改元素 list. Set(1, aaa); // 遍历集合 for (String s : list) {System.out.println(s); } 不过LinkedList 和 ArrayList 仍然有较大的不同 LinkedList 是由双向链表实现的不支持随机存取只能从一端开始遍历直到找到需要的元素后返回任意位置插入和删除元素都很方便因为只需要改变前一个节点和后一个节点的引用即可不像 ArrayList 那样需要复制和移动数组元素因为每个元素都存储了前一个和后一个节点的引用所以相对来说占用的内存空间会比 ArrayList 多一些。 (3) Vector 和 Stack List 的实现类还有一个 Vector是一个元老级的类比 ArrayList 出现得更早。ArrayList 和 Vector 非常相似只不过 Vector 是线程安全的像 get、set、add 这些方法都加了 synchronized 关键字就导致执行效率会比较低所以现在已经很少用了。 看一下 add 方法的源码 public synchronized boolean add(E e) {elementData[elementCount] e;return true; } 这种加了同步方法的类注定会被淘汰掉就像StringBuilder 取代 StringBuffer那样。JDK 源码也说了 如果不需要线程安全建议使用 ArrayList 代替 Vector。 Stack 是 Vector 的一个子类本质上也是由动态数组实现的只不过还实现了先进后出的功能在 get、set、add 方法的基础上追加了 pop「返回并移除栈顶的元素」、peek「只返回栈顶元素」等方法所以叫栈。 下面是这两个方法的源码增删改查我就不写了和 ArrayList 和 LinkedList 几乎一样。 public synchronized E pop() {E obj;int len size();obj peek();removeElementAt(len - 1);return obj; }public synchronized E peek() {int len size();if (len 0)throw new EmptyStackException();return elementAt(len - 1); } 不过由于 Stack 执行效率比较低方法上同样加了 synchronized 关键字就被双端队列 ArrayDeque 取代了. 二、Set Set 的特点是存取无序不可以存放重复的元素不可以用下标对元素进行操作和 List 有很多不同。 1HashSet HashSet 其实是由 HashMap 实现的只不过值由一个固定的 Object 对象填充而键用于操作。来简单看一下它的源码。 public class HashSetEextends AbstractSetEimplements SetE, Cloneable, java.io.Serializable {private transient HashMapE,Object map;// Dummy value to associate with an Object in the backing Mapprivate static final Object PRESENT new Object();public HashSet() {map new HashMap();}public boolean add(E e) {return map.put(e, PRESENT)null;}public boolean remove(Object o) {return map.remove(o)PRESENT;} } 实际开发中HashSet 并不常用比如如果我们需要按照顺序存储一组元素那么 ArrayList 和 LinkedList 可能更适合如果我们需要存储键值对并根据键进行查找那么 HashMap 可能更适合。 来一段增删改查体验一下 // 创建一个新的HashSet HashSetString set new HashSet();// 添加元素 set. Add(aa); set. Add(bb); set. Add(ccc);// 输出HashSet的元素个数 System.out.println(HashSet size: set.size()); // output: 3// 判断元素是否存在于HashSet中 boolean containsWanger set. Contains(bb); System.out.println(Does set contain bb? containsWanger); // output: true// 删除元素 boolean removeWanger set. Remove(bb); System.out.println(Removed bb? removeWanger); // output: true// 修改元素需要先删除后添加 Boolean removeChenmo set. Remove(aa); Boolean addBuChenmo set. Add(aaa); System.out.println(Modified set? (removeChenmo addBuChenmo)); // output: true// 输出修改后的HashSet System.out.println(HashSet after modification: set); // output: [ccc, aaa] HashSet 主要用于去重比如我们需要统计一篇文章中有多少个不重复的单词就可以使用 HashSet 来实现。 // 创建一个 HashSet 对象 HashSetString set new HashSet();// 添加元素 set. Add(aa); set. Add(bb); set. Add(ccc); set. Add(aa);// 输出 HashSet 的元素个数 System.out.println(HashSet size: set.size()); // output: 3// 遍历 HashSet for (String s : set) {System.out.println(s); } 从上面的例子可以看得出HashSet 会自动去重因为它是用 HashMap 实现的HashMap 的键是唯一的哈希值相同键的值会覆盖掉原来的值于是第二次 set.add(沉默) 的时候就覆盖了第一次的 set.add(aa)。 (2)LinkedHashSet LinkedHashSet 虽然继承自 HashSet其实是由 LinkedHashMap 实现的。 这是 LinkedHashSet 的无参构造方法 public LinkedHashSet() {super(16, .75f, true); } super 的意思是它将调用父类的 HashSet 的一个有参构造方法 HashSet(int initialCapacity, float loadFactor, boolean dummy) {map new LinkedHashMap(initialCapacity, loadFactor); } LinkedHashSet 的增删改查 LinkedHashSetString set new LinkedHashSet();// 添加元素 set. Add(aa); set. Add(bb); set. Add(ccc);// 删除元素 set. Remove(bb);// 修改元素 set. Remove(aa); set. Add(aaaaa);// 查找元素 Boolean hasChenQingYang set. Contains(ccc); System.out.println(set包含ccc吗 hasccc); 在以上代码中我们首先创建了一个 LinkedHashSet 对象然后使用 add 方法依次添加了三个元素aa、bb和ccc。接着我们使用 remove 方法删除了bb这个元素并使用 remove 和 add 方法修改了aa这个元素。最后我们使用 contains 方法查找了ccc这个元素是否存在于 set 中并打印了结果。 LinkedHashSet 是一种基于哈希表实现的 Set 接口它继承自 HashSet并且使用链表维护了元素的插入顺序。因此它既具有 HashSet 的快速查找、插入和删除操作的优点又可以维护元素的插入顺序。 (3)TreeSet 与 TreeMap 相似TreeSet 是一种基于红黑树实现的有序集合它实现了 SortedSet 接口可以自动对集合中的元素进行排序。按照键的自然顺序或指定的比较器顺序进行排序。 // 创建一个 TreeSet 对象 TreeSetString set new TreeSet();// 添加元素 set. Add(aa); set. Add(bb); set. Add(ccc); System.out.println(set); // 输出 [aa, bb, ccc]// 删除元素 set. Remove(bb); System.out.println(set); // 输出 [aa, ccc]// 修改元素TreeSet 中的元素不支持直接修改需要先删除再添加 set. Remove(ccc); set. Add(cbc); System.out.println(set); // 输出 [aa, cbc]// 查找元素 System.out.println(set. Contains(aa)); // 输出 true System.out.println(set. Contains(bb)); // 输出 false 需要注意的是TreeSet 不允许插入 null 元素否则会抛出 NullPointerException 异常。 总体上来说Set 集合不是关注的重点因为底层都是由 Map 实现的为什么要用 Map 实现呢 因为 Map 的键不允许重复、无序. 参考链接https://javabetter.cn/collection/gailan.html
http://www.tj-hxxt.cn/news/130706.html

相关文章:

  • 网站设计营销门户网站的推广
  • 个人博客网站html模板wordpress 问答 api
  • 广州网站建设(信科网络)阳区城市规划建设局网站
  • 网站建设与维护课程标准济南公众平台网站建设
  • 网站建设与管理实训报告wordpress的链接功能
  • asp怎么做网站重庆seo关键词排名
  • 网站放到服务器wordpress dux主题首页
  • 贵阳市网站开发建设局网站更改法人所需材料
  • asp.net 如何设置网站首页北京市在建工程项目查询
  • 网站系统制作教程如何用手机开发游戏
  • .net网站开发的例子h5可以做网站吗
  • 门户网站推荐国内网站建设哪家好
  • 如何用服务器搭建网站如何在网上做网站推广
  • 莱州市建设局网站wordpress和dedecms哪个好
  • 网站建设续费是那些充值中心网站怎么做
  • 网站建设往年的高考题推广平台有哪几个
  • 建网站的公司服务中国flash网站模板中心
  • 沈阳网站制作的公司哪家好免费推广的软件
  • 营商环境建设监督局网站安徽公路建设行业协会网站是哪个
  • 沈阳专门代做网站的设计ui
  • 东莞企业网站设计排名软件开发工程师证书怎么考
  • seo网站编辑免费公司网站建站
  • 网站建设与维护期末试卷百度网站排名优化
  • 十大网站央企 网站建设 公司
  • 深圳网站建设及优化投资网站哪个好
  • 极速网站建设服务商网站开发加维护需要多少钱
  • 深圳网站建设门户谁用fun域名做网站了
  • 江苏天宇建设集团网站合肥效果图制作公司
  • 南通做公司网站电子商务适合女生学吗
  • 海口模板建站系统建筑模板厂家大全