Java集合学习(一)

ArraysList

ArraysList集合就像C++中的vector容器,它可以不考虑其容器的长度,就像一个大染缸一

样,无穷无尽的丢进去也没问题。Java的数据结构和C有许多的共同之处,希望在学习的

过程中可以相互借鉴。

以下为ArraysList的使用方法: 首先创建ArraysList对象: ArraysList A = new ArraysList();

  1. 添加对象实例: 有两种添加方法,一是直接添加,放到后面去,二是指定位置添加:

一直接添加:A.add(  对象名 );   二: 指定位置添加 : A.add(  数字 , 对象名  );

  1. 判断容器是否存在某对象: A.comtains( 对象名 ) //是判断是否是同一个对象
  2. 获取指定位置的对象 : A. get ( 数字 )
  3. 获取对象的指定位置 : A.indexOf ( 对象名 )
  4. 获取并删除 :A.remove( 数字)
  5. 替换 : A.set( 数字 , 要替换的对象   )
  6. 获取大小 : A.size();
  7. 转换为数组 : Hero H[] = (Hero[]) A.toArrays(new Hero[]{})
  8. 把另一个容器的对象都加进来:A.addAll( 容器名 );
  9. 清空: A.clear();

虽然ArraysList有着太多的方便,但是因为有着太多的各种不同的类的对象,这会导致

强制转换出现问题,于是,泛型就出现了,泛型要求一个ArraysList只能存入一种类型的

对象,这样既保存了方便,又可以避免类型错误。

创建一个泛型: List<Hero> Ls = new ArraysList<>();

原则:只能存放该类型以及其子类。

遍历方法:

  1. 利用for循环进行便利,for( int i = 0 ; i < A.size() ; i++){}
  2. 迭代器经行遍历:

创建迭代器: Iterator It = A.iterator();

循环:A.hasNext();

获取对象:Hero H = A.next();

  1. 增强型for循环 :for( Hero H : A){}

===============================================================================

LinKedList

LinkedList同样实现了list接口,可以拥有和ArraysList一样的方法,除此之外,它还实现了Deque接口,它

的储存方式像链表一样,可以很方便的在头部或尾部进行插入或删除(但也不是一般的链表,是双向链表)

创建LinkedList容器:

LinkedList<Hero> Hs = new LinkedList<>();

区别于ArraysList之外的特殊的使用方法:

查看首部元素:    Hs.getFirst(  );

查看尾部元素:   Hs.getLast(  );

获取并删除首部元素:   Hs.removeFirst(  );

获取并删除尾部元素:   Hs.removeLast(  );

除此之外,LinkedList也实现了Queue接口,可以作为队列使用,以下是将LinkedList作为队列使用的方法:

  1. 将元素插入后面:Hs.offer( new Hero(“盖伦”);
  2. 取出并删除第一个元素:Hs.poll();
  3. 拿第一个元素出来瞧一瞧但放回去 : Hs.peek();

讨论:Arrayslist 和 LinkedList的区别:

ArraysList 插入数据,删除数据 效率低下

LinkedList 插入数据,删除数据 速度很快

ArraysList 定位很快

LinkedList 定位很慢

2019/3/2周末 java集合学习(一)的更多相关文章

  1. 2019/3/4 java集合学习(二)

    java集合学习(二) 在学完ArrayList 和 LinkedList之后,基本已经掌握了最基本的java常用数据结构,但是为了提高程序的效率,还有很多种特点各异的数据结构等着我们去运用,类如可以 ...

  2. 转:深入Java集合学习系列:HashSet的实现原理

    0.参考文献 深入Java集合学习系列:HashSet的实现原理 1.HashSet概述: HashSet实现Set接口,由哈希表(实际上是一个HashMap实例)支持.它不保证set 的迭代顺序:特 ...

  3. Java集合学习(9):集合对比

    一.HashMap与HashTable的区别 HashMap和Hashtable的比较是Java面试中的常见问题,用来考验程序员是否能够正确使用集合类以及是否可以随机应变使用多种思路解决问题.Hash ...

  4. java集合学习(2):Map和HashMap

    Map接口 java.util 中的集合类包含 Java 中某些最常用的类.最常用的集合类是 List 和 Map. Map 是一种键-值对(key-value)集合,Map 集合中的每一个元素都包含 ...

  5. 深入java集合学习1-集合框架浅析

    前言 集合是一种数据结构,在编程中是非常重要的.好的程序就是好的数据结构+好的算法.java中为我们实现了曾经在大学学过的数据结构与算法中提到的一些数据结构.如顺序表,链表,栈和堆等.Java 集合框 ...

  6. java集合学习一

    首先看一下java集合的关系图 1.1从全面了解Java的集合关系图.常见集合  list  set map等其中我们最常用的 list  map 结合.几天说一下常见的map.map在我工作的两年里 ...

  7. Java集合学习总结

    java集合 collection public interface Collection<E> extends Iterable<E> List public interfa ...

  8. Java 集合学习--HashMap

    一.HashMap 定义 HashMap 是一个基于散列表(哈希表)实现的键值对集合,每个元素都是key-value对,jdk1.8后,底层数据结构涉及到了数组.链表以及红黑树.目的进一步的优化Has ...

  9. java集合学习(1):集合框架

    集合 Collection(有时候也叫container)是一个简单的对象, Java集合工具包位于Java.util包下,Java集合主要可以划分为4个部分:List列表.Set集合.Map映射.工 ...

随机推荐

  1. javaMail实现收发邮件(四)

    JavaMail API中也提供了一些专门的类来对邮件的接收进行相关的操作,在介绍这些类之前,我们先来了解下邮件接收API的体系结构,JavaMai API中定义了一个java.mail.Store类 ...

  2. Jenkins master slave设置遇到的坑以及解决办法

    写好了selenium测试脚本,本地运行没问题,但是现在流行分布式运行,并行执行以显得高大上. 然而,装高大上是要付出代价的. Selenium Grid 已经完美实现分布式和并行了. 奈何现在会Je ...

  3. webpack多入口优化

    最近接手的项目是公司之前搭的多页面应用脚手架,然后到现在入口页面大大小小超过半百了,然后每次更新完配置之后,重启页面就贼拉卡,实在太影响开发效率了,于是开始优化呗. 最开始发现如果你想要让加载速度变快 ...

  4. hdu 3065 AC自动机 标记数组不清零

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3065 题目里面要我们计算每种单词出现的次数,重叠的也要计算,那么我们在查找的时候不要把标记单词结尾的 ...

  5. 大数据实操3 - hadoop集群添加新节点

    hadoop集群支持动态扩展,不需要停止原有集群节点就可以实现新节点的加入. 我是使用docker搭建的进群环境,制作了镜像文件,这里以我的工作基础为例子介绍集群中添加集群的方法 一.制作一个新节点 ...

  6. 微信小程序记账本进度四

    //index.wxml <view class="container"> <form catchsubmit="formSubmit" &g ...

  7. python的re模块详解

    一.正则表达式的特殊字符介绍 正则表达式 ^ 匹配行首 $ 匹配行尾 . 任意单个字符 [] 匹配包含在中括号中的任意字符 [^] 匹配包含在中括号中的字符之外的字符 [-] 匹配指定范围的任意单个字 ...

  8. linklist和arraylist区别

    ArrayList更适合读取数据,linkedList更多的时候添加或删除数据.

  9. Jenkins+docker自动部署

    项目目录结构如下 对此项目,使用Jenkins构建dockers镜像 步骤如下: 1.安装Jenkins和docker,具体安装步骤,自行度娘把,在此不详述了. 2.Jenkins安装插件Gradle ...

  10. 使用jconsole分析内存情况-JVM

    JVM调优分析演练: Jconsole中对内存为如下结构: 原始代码: public static void main(String[] args) { BigInteger [] pArr=new ...