集合 ArrayList

丑数: 能被3,5,7整除多次,

ArrayList

    list 接口

            | - ArrayList

            | - LinkedList

    ArrayList 内部封装一个数组

    用数组存放数据

    默认初始容量是 10,

    放满后会新建1.5倍的长度的新数组

    之前数据复制放入新数组,之前数组释放

    数组访问效率高,任意位置都是

    但是增删数据效率可能低

    创建对象

           new ArrayList();

           初始容量10

           new ArrayList(1000);

           初始容量 指定 1000

    方法

           与LinkedList 相同

           没有两端操作数据的方法

           iterator();方法

                    hasNext();

                    next();

                    remove();  

            迭代器遍历期间,不能使用 list 增删数据,

            迭代期间删除必须使用 iterator.remove();

          

   HashMap  哈希表 / 散列表

             存放键值对数据

             键不重复,数据无序

                          

             作用: 用键快速查找速度

              方法:

                   put(key,value); 放入键值对数据,重复键覆盖原值

                   get(key);取键对应的值,键不存在 返回 null

                   size();键值对的数量

                   remove(key);移除键值对,返回被移除的值

                   keySet(); 把HashMap 里面所有键取出放入HashSet里面

  •  哈希算法      

  1. 用数组存放数据,初始长度16

  2. 存放数据的过程: 先获得键的哈希值, key.hashCode();
  3. 用哈希值和数组长度来计算一个下标值 index
  4. 将键和值进行封装成 Entry 对象
  5. Entry 对象,放入 index 位置

空位置,直接放入

有数据,依次用 equals() 比较键是否相等

找到相等的,覆盖值

没有相等,链表连在一起

负载率,加载因子到 0.75(既数据数量到数组容量的0.75)

新建容量翻倍的新数组

所有数据,重新哈希,放入新数组

jdk 1.8以后

链表长度到 8, 转成红黑树(二叉树结构,小的往左放,大的往右放)(比大小比键的哈希值)

红黑树长度减少到 6, 转成链表

  • HasCode()  
  1. 从object 继承的方法
  2. 默认实现是使用内存地址值作为哈希值
  3. 可以在子类中重写这个方法, 用对象的属性数据计算哈希值
  • HashSet
  1. 用hashmap 放数据
  2. 数据不重复且无需
  3. 方法:
  4. add(数据)
  5. remove(数据)
  6. size()
  7. iterator() 迭代器
  •    Iterator 接口
  1. 使用集合的 iterator() 方法创建的迭代器对象,都是接口的子类型对象
  2. 迭代器使用期间,不能直接使用集合来增删数据
  3. 方法:
  4. hashNext()
  5. next()
  6. remove()
  •  Collections 工具类
  1. addAll(集合,值1,值2,值3,值4...); 集合多个添加数据
  2. sort(集合);排序   可以自己设置比较器
  3. binarySerarch(集合,目标值);  有序集合二分法查找,可以自己设置比较器
  4. swap(集合,a,b);交换a,b 位置
  • for-erch 循环
    • 是对数组遍历访问,集合迭代遍历访问的语法简化
    • for-each简化语
    •  for(String s :a){
      // 处理 s
      }
    • 集合的迭代遍历
for(Iterator<Intger>it=list.iterator;it.hasNext();){
Integer s = it.next();
}
    • for-each简化语法

      for(String s : list){
      
      }
    • foreach 语法, 对集合有要求
      • 要求集合必须实现 Iterable 接口
      • 必须是 Iterable 接口的子类,才能用foreach

       

java - day011 - 集合, ArrayList HashMap,HashSet, Iterator 接口, for-each 循环格式的更多相关文章

  1. java 数据结构(八):Iterator接口与foreach循环

    1.遍历Collection的两种方式:① 使用迭代器Iterator ② foreach循环(或增强for循环)2.java.utils包下定义的迭代器接口:Iterator2.1说明:Iterat ...

  2. java集合(2)-Collection与Iterator接口

    1 package com.j1803.collectionOfIterator; 2 import java.util.ArrayList; 3 import java.util.Collectio ...

  3. java集合 之 Collection和Iterator接口

    Collection是List,Queue和Set接口的父接口,该接口里定义的方法即可用于操作Set集合,也可以用于List和Queue集合.Collection接口里定义了如下操作元素的方法. bo ...

  4. 浅谈Java语言中ArrayList和HashSet的区别

    Java语言中ArrayList和HashSet的区别 2019-04-10   13:22:49 一.基本区别 首先一起看个实例,其代码如下: package com.MrZ_baby.com; i ...

  5. Java中如何克隆集合——ArrayList和HashSet深拷贝

    编程人员经常误用各个集合类提供的拷贝构造函数作为克隆List,Set,ArrayList,HashSet或者其他集合实现的方法.需要记住的是,Java集合的拷贝构造函数只提供浅拷贝而不是深拷贝,这意味 ...

  6. Java集合【2】--iterator接口详解

    目录 一.iterator接口介绍 二.为什么需要iterator接口 三.iterator接口相关接口 3.1 ListIterator 3.2 SpitIterator 3.2.1 SpitIte ...

  7. Java容器深入浅出之Collection与Iterator接口

    Java中用于保存对象的容器,除了数组,就是Collection和Map接口下的容器实现类了,包括用于迭代容器中对象的Iterator接口,构成了Java数据结构主体的集合体系.其中包括: 1. Co ...

  8. 【Java必修课】ArrayList与HashSet的contains方法性能比较(JMH性能测试)

    1 简介 在日常开发中,ArrayList和HashSet都是Java中很常用的集合类. ArrayList是List接口最常用的实现类: HashSet则是保存唯一元素Set的实现. 本文主要对两者 ...

  9. JAVA基础——集合——ArrayList

    ArrayList集合 ArrayList的一些方法(JDK1.8): 将指定的元素附加到列表的末尾,true:添加成功,false:添加失败: public boolean add(E e)    ...

随机推荐

  1. LeetCode_258. Add Digits

    258. Add Digits Easy Given a non-negative integer num, repeatedly add all its digits until the resul ...

  2. Delphi XE中使用dbExpress连接MySQL数据库疑难问题解决

    Delphi IDE中包含一个Data Explorer的组件,如下图所示: 该组件基于dbExpress(包含TSQLConnection.TSQLDataSet.TSQLQuery.TSQLSto ...

  3. WXSS选择器

  4. Clean Code 代码整洁之道

    军规:让营地比你来时更干净. 整洁代码 Leblanc : Later equals never. (勒布朗法则:稍后等于永不) 对代码的每次修改都影响到其他两三处代码. 修改无小事. 如同医生不能遵 ...

  5. Python标准库: functools (cmp_to_key, lru_cache, total_ordering, partial, partialmethod, reduce, singledispatch, update_wrapper, wraps)

    functools模块处理的对象都是其他的函数,任何可调用对象都可以被视为用于此模块的函数. 1. functools.cmp_to_key(func) 因为Python3不支持比较函数,cmp_to ...

  6. 微信小程序之一:动态添加view(view包含picker,input)

    <view wx:for="{{array}}" wx:key="this" class="borderContainer"> ...

  7. GSVA的使用

    GSVA的简介 Gene Set Variation Analysis,被称为基因集变异分析,是一种非参数的无监督分析方法,主要用来评估芯片核转录组的基因集富集结果.主要是通过将基因在不同样品间的表达 ...

  8. qt linux下自动检测U盘热插拔

    如果用U盘来更新软件,需要先删除当前的可执行文件,但是如果删除之后,复制失败的话会导致后续没有文件可以运行了.一个方法是将新的可执行文件放到另一个目录中,当copy成功后修改linux的启动文件,然后 ...

  9. 030 Android 第三方开源下拉框:NiceSpinner的使用+自定义Button样式+shape绘制控件背景图+图片选择器(selector)

    1.NiceSpinner下拉框控件介绍 Android原生的下拉框Spinner基本上可以满足Android开发对于下拉选项的设计需求,但现在越来越流行的下拉框不满足于Android原生提供的下拉框 ...

  10. [Asp.Net Core] - 使用 ViewComponents 实现分页控件

    分页控件(定义分页参数) ~/ViewComponents/PaginationViewComponent.cs using HelloWorld.DataContext; using Microso ...