俗话说:一个东西,一件事都离不开三句话:“是什么,为什么,怎么办”

集合是什么:

集合简单的说一个数组集合的高级体现,用来存储数据或对象的容器;

集合为什么存在:

集合只是体现了对数据操作的灵活度;大大方便了开发者的效率;

集合怎么使用:

使用分了以下几种方式:        Collection     集合   1.list    2.Set

List

          List            底层数据结构   查询 增删 线程   效率
 ArrayList     数组  不安全
Vector   数组 安全
LinkedList       链表   不安全    高

Set

Set 底层数据结构 有序 唯一 排序
HashSet 哈希表 是(依赖hashCode()和equals()) --
LinkedhashSet 链表和哈希表

由链表保证元素有序
由哈希表保证元素唯一

--
TreeSet 红黑树 --

a.自然排序

b.比较器排序

(4)Collection的功能概述

List cn=new ArrayList();
     A:添加功能

add(Object e);//直接自然顺序插入

add(index, element);//按索引插入
     B:删除功能

remove(index);//根据索引移除
     C:判断功能

cn.contains(object e)//判断cn集合中是否存在元素e
     D:获取功能

cn.get(index)//跟据索引获取值
     E:长度功能

cn.size()//返回集合长度
     F:交集(了解)

cn.retainAll(Collection c)//cn对c做交集

cn对c做交集  返回值是boolean值

有交集       则返回true  存在交际则cn集合中的值会返回交集值

无交集        则返回false
    G:把集合转数组

cn.toArray()
(5)Collection集合的遍历
     A:把集合转数组(一般不用)

遍历集合 改成 遍历数组
     B:迭代器(集合专用方式) 
           迭代器

//创建cn集合对象的迭代器

iterator it=cn.iteraror();

while(it.hasnext())

{System.out.println(it.next())}
           1:是集合的获取元素的方式。
           2:是依赖于集合而存在的。
           3:迭代器的原理和源码。
                   a:为什么定义为了一个接口而不是实现类?

简单的说:不管是哪一种集合,我们都要获取集合中的数据,并且在获取之前辅助于判断功能,也就是说在获取元素之前先进行判断,那么集合就有两个功能(判断,查询)。这样如果是实现类只能去实现某一个集合,反而接口可以做到,让子类自己去实现接口,这样就达到要求了;

(5)并发修改异常
    A:出现的现象
          迭代器遍历集合,集合修改集合元素
    B:原因
          迭代器是依赖于集合的,而集合的改变迭代器并不知道。
    C:解决方案
          a:迭代器遍历,迭代器修改(ListIterator)
                元素添加在刚才迭代的位置
          b:集合遍历,集合修改(size()和get())
                元素添加在集合的末尾
  (6)常见数据结构
         A:栈 先进后出
         B:队列 先进先出
         C:数组 查询快,增删慢
         D:链表 查询慢,增删快

浅谈Collection集合的更多相关文章

  1. 浅谈JAVA集合框架

    浅谈JAVA集合框架 Java提供了数种持有对象的方式,包括语言内置的Array,还有就是utilities中提供的容器类(container classes),又称群集类(collection cl ...

  2. 浅谈 Java集合

    Java 集合 集合是对象的容器,定义了多个对象进行操作的常用方法,可实现数组的功能. Java集合类库所处位置:java.util.*. 与现代的数据结构类库的常见做法一样,Java集合类库也将接口 ...

  3. 浅谈JAVA集合框架(转载)_常用的Vector和HashMap

    原作者滴着:http://www.cnblogs.com/eflylab/archive/2007/01/20/625237.html Java提供了数种持有对象的方式,包括语言内置的Array,还有 ...

  4. 浅谈Swift集合类型

    Swift 的集合表现形式由数组和字典组成.它可以完美的存储任何呢想存储的东西. 数组是一个同类型的序列化列表集合,它用来存储相同类型的不同值.字典也是一个数组,但它的存值方式类似于Map,通过一对一 ...

  5. 浅谈C#集合【转】

    集合是.NET FCL(Framework Class Library)中很重要的一部分,也是我们开发当中最常用到的功能之一,几乎是无处不在.俗话说知其然,知其所以然,平常看到IEnumerable, ...

  6. 浅谈Java集合体系及底层实现原理

    集合加载因子 https://blog.csdn.net/qq_34627002/article/details/79769261 底层原理: https://blog.csdn.net/qq_258 ...

  7. 浅谈Java的集合框架

    浅谈Java的集合框架 一.    初识集合 重所周知,Java有四大集合框架群,Set.List.Queue和Map.四种集合的关注点不同,Set 关注事物的唯一性,List 关注事物的索引列表,Q ...

  8. 铁乐学Python_day07_集合and浅谈深浅copy

    1.[List补充] 在循环一个列表时,最好不要使用元素和索引进行删除操作,一旦删除,索引会随之改变,容易出错. 如果想不出错,可以采用倒着删除的方法,因为倒着删除进行的话,只是后面元素的位置发生了变 ...

  9. C#集合类型——Array、ArrayList、List 之浅谈

    在学习或工作中,集合是经常用到的,可以换一句话说“无项目无集合”,“项目皆有集合”.它一般存储一系列数据或者将一系列数据进行相关操作.在这里先大略谈一些集合类型的相关知识用于回顾. 数组(Array) ...

随机推荐

  1. 消息队列性能对比——ActiveMQ、RabbitMQ与ZeroMQ(译文)

    Dissecting Message Queues 概述: 我花了一些时间解剖各种库执行分布式消息.在这个分析中,我看了几个不同的方面,包括API特性,易于部署和维护,以及性能质量..消息队列已经被分 ...

  2. css text-fill-color与text-stroke讲解

    顾名思义"text-fill-color"就是文字填充颜色而"text-stroke"就是文字描边.还别说,两个属性可以制作出各种炫酷的文字效果,不过IE系列都 ...

  3. 自制Azure中国版“加血包”

    Micrsoft Azure中国版的国际出口最近升级为电话线拨号模式,目测为10个用户共享一条56kb的电话线拨号链路.有图有真相: 中国的IT从业者,有三分之一的职业生涯时间是在跟网络斗智斗勇.这点 ...

  4. 借助 SIMD 数据布局模板和数据预处理提高 SIMD 在动画中的使用效率

    原文链接 简介 为发挥 SIMD1 的最大作用,除了对其进行矢量化处理2外,我们还需作出其他努力.可以尝试为循环添加 #pragma omp simd3,查看编译器是否成功进行矢量化,如果性能有所提升 ...

  5. css样式让input垂直居中

    css样式让input垂直居中 css代码: .div1{ border: 1px solid #CCC; width:1120px; height:40px; margin:auto; displa ...

  6. MONO x64 amd_x64

    SharpPcap 是一个.NET 环境下的网络包捕获框架,基于著名的 pcap/WinPcap 库开发.提供了捕获.注入.分析和构建的功能,SharpPcap 还是一个跨平台的库,可以在Mono/. ...

  7. 从零开始,DIY一个jQuery(2)

    在上篇文章我们简单实现了一个 jQuery 的基础结构,不过为了顺应潮流,这次咱把它改为模块化的写法,此举得以有效提升项目的可维护性,因此在后续也将以模块化形式进行持续开发. 模块化开发和编译需要用上 ...

  8. SpringMVC的Action在同一时间里只允许同一个浏览器的单次进入?

    最近用SpringMVC写了一个很简单的测试程序,代码如下: @Controller public class LongTimeTaskController { @RequestMapping(val ...

  9. Jquery双向select控件Bootstrap Dual Listbox

    效果预览: 一. 下载插件 github地址:https://github.com/istvan-ujjmeszaros/bootstrap-duallistbox 也可以在这个网站中下载:http: ...

  10. Leetcode 笔记 110 - Balanced Binary Tree

    题目链接:Balanced Binary Tree | LeetCode OJ Given a binary tree, determine if it is height-balanced. For ...