String

  • String类是不可修改的,创建需要修改的字符串需要使用StringBuffer(线程同步,安全性更高)或者StringBuilder(线程非同步,速度更快)。
  • 可以用“+”连接String。
  • 用String.format()创建格式化字符串。

ArrayList

  • 动态数组,可以动态的增加或者减少元素。
  • 常用操作:
    • 创建:ArrayList<Type> arrayList=new ArrayList<>();
    • 添加元素:add
    • 获取元素:get
    • 删除元素:remove
    • 获取数组大小:size
    • 判断是否包含某一元素:contains
    • 设置元素:set
    • 清空数组:clear
    • 判断是否为空:isEmpty
  • 遍历方式:通过下标索引效率最高
  • Type temp;
    for(int i=0;i<arrayList.size();i++){
    temp=arrayList.get(i);
    }
  • arrayList排序需要实现Comparator接口以实现自定义排序
  • Comparator<String> comparator=new Comparator<String>() {
    @Override
    public int compare(String o1, String o2) {
    if(o1.compareTo(o2)>0) return 1;
    if(o1.compareTo(o2)<0) return -1;
    return 0;
    }
    };

Stack

  • 由vector拓展而来
  • 常用操作:push,peak,pop,search,isEmpty
  • public static void stackTest() {
    Stack<String> stack=new Stack<String>();
    //将元素压入栈顶
    System.out.println(stack.push("haha"));
    System.out.println(stack.push("yes"));
    //栈顶元素的search结果为1,然后从栈顶向栈底依次递增
    System.out.println(stack.search("haha"));
    //查看栈顶元素
    System.out.println(stack.peek());
    //弹出栈顶元素并返回栈顶元素
    System.out.println(stack.pop());
    //判断栈是否非空
    System.out.println(stack.isEmpty());
    }

Queue

  • 是一个接口,LinkedList实现Queue接口
  • 常用操作:offer,peek,poll,isEmpty
  • public static void queueTest() {
    //LinkedList实现了Queue接口,所以构造时使用LinKedList
    Queue<String> queue=new LinkedList<String>();
    //在队列尾部增加元素,并返回是否增加成功
    System.out.println(queue.offer("abc"));
    System.out.println(queue.offer("def"));
    //返回队首元素,若队列空,则返回null;(ps:element在队列空时抛出异常)
    System.out.println(queue.peek());
    //弹出队首元素,并返回队首元素,若队列空则返回null
    System.out.println(queue.poll());
    //判断队列是否空
    System.out.println(queue.isEmpty());
    }

LinkedList

  • 双向链表,非同步
  • 常用操作:addFirst,addLast,add,getFirst,getLast,get,removeFirst,removeLast,remove,isEmpty
    public static void linkedlistTest() {
    LinkedList<String> linkedList=new LinkedList<String>();
    //在链表头部加,尾部加,任意位置加元素
    linkedList.addFirst("haha");
    linkedList.addLast("yali");
    linkedList.add(1, "good");
    //输出链表
    System.out.println("first element:"+linkedList.getFirst());
    System.out.println("last element:"+linkedList.getLast());
    for(int i=0;i<linkedList.size();i++) System.out.println(linkedList.get(i));
    //删除任意位置,头部,尾部的链表元素
    linkedList.remove(1);
    linkedList.removeFirst();
    linkedList.removeLast();
    //判断链表是否空
    System.out.println(linkedList.isEmpty());
    }

HashMap

  • 非同步
  • public static void hashmapTest() {
    HashMap<String, Integer> hashMap=new HashMap<String, Integer>();
    //向哈希表中添加元素
    hashMap.put("tp", 123);
    hashMap.put("zp", 567);
    System.out.println(hashMap);
    //通过迭代器便利哈希表
    for(Iterator<Entry<String, Integer>> iterator=hashMap.entrySet().iterator();iterator.hasNext();){
    Entry<String, Integer> entry=iterator.next();
    System.out.println(entry.getKey());
    System.out.println(entry.getValue());
    }
    //查找哈希表中是否有该键
    System.out.println(hashMap.containsKey("he"));
    //查找哈希表是否有该值
    System.out.println(hashMap.containsValue(567));
    //删除哈希表中的键值对
    hashMap.remove("tp");
    System.out.println(hashMap);
    }

SUMMARY | JAVA中的数据结构的更多相关文章

  1. java中的数据结构(集合|容器)

    对java中的数据结构做一个小小的个人总结,虽然还没有到研究透彻jdk源码的地步.首先.java中为何需要集合的出现?什么需求导致.我想对于面向对象来说,对象适用于描述任何事物,所以为了方便对于对象的 ...

  2. [转]详细介绍java中的数据结构

    详细介绍java中的数据结构 本文介绍的是java中的数据结构,本文试图通过简单的描述,向读者阐述各个类的作用以及如何正确使用这些类.一起来看本文吧! 也许你已经熟练使用了java.util包里面的各 ...

  3. 详细介绍java中的数据结构

    详细介绍java中的数据结构 http://developer.51cto.com/art/201107/273003.htm 本文介绍的是java中的数据结构,本文试图通过简单的描述,向读者阐述各个 ...

  4. Java中的数据结构及排序算法

    (明天补充) 主要是3种接口:List Set Map List:ArrayList,LinkedList:顺序表ArrayList,链表LinkedList,堆栈和队列可以使用LinkedList模 ...

  5. 动图+源码,演示Java中常用数据结构执行过程及原理

    最近在整理数据结构方面的知识, 系统化看了下Java中常用数据结构, 突发奇想用动画来绘制数据流转过程. 主要基于jdk8, 可能会有些特性与jdk7之前不相同, 例如LinkedList Linke ...

  6. 动图+源码,演示 Java 中常用数据结构执行过程及原理

    ​阅读本文大概需要 3.7 分钟. 作者:大道方圆 cnblogs.com/xdecode/p/9321848.html 最近在整理数据结构方面的知识, 系统化看了下Java中常用数据结构, 突发奇想 ...

  7. Java中的数据结构有哪些?HashMap的工作原理是什么?

    Java中常用数据结构 常用的数据结构有哈希表,线性表,链表,java.util包中有三个重要的接口:List,Set,Map常用来实现基本的数据结构 HashMap的工作原理 HashMap基于ha ...

  8. Java中的数据结构-HashMap

    Java数据结构-HashMap 目录 Java数据结构-HashMap 1. HashMap 1.1 HashMap介绍 1.1.1 HashMap介绍 1.1.2 HashMap继承图 1.2 H ...

  9. 18、Java中的 数据结构

    Java2中引入了新的数据结构 集合框架 Collection,下一节再谈论(非常重要,面试也常问). 1.枚举 (Enumeration) 1.1 Enumeration 源码: public in ...

随机推荐

  1. 关于SecureCRT链接服务器出现乱码的问题

    连接到服务器,选择上方的“选项”->“会话选项”->“外观”->右边的字符编码->utf-8

  2. NX二次开发-UFUN获取NX系统默认导出CGM的选项设置UF_CGM_ask_default_export_options

    文章转载自唐康林NX二次开发论坛,原文出处: http://www.nxopen.cn/thread-126-1-1.html 刚才有同学问到这个问题,如果是用NXOpen来做,直接录制一下就可以了: ...

  3. sqlserver 调优(二)

    良好的系统和数据库设计,优质的SQL编写,合适的数据表索引设计,甚至各种硬件因素:网络性能.服务器的性能.操作系统的性能,甚至网卡.交换机等.这篇文章主要讲到如何改善SQL语句,还将有另一篇讨论如何改 ...

  4. Spring-Security (学习记录七)--实现FilterInvocationSecurityMetadataSource的类将无法切入声明式事物

    目录 1 查看继承关系 2 说明 3 查看源码: 实现了FilterInvocationSecurityMetadataSource 的类将无法切入声明式事物. 原因: 1 查看继承关系 先查看Fil ...

  5. 使用Devstack部署neutron网络节点

    本文为minxihou的翻译文章,转载请注明出处Bob Hou: http://blog.csdn.net/minxihou JmilkFan:minxihou的技术博文方向是 算法&Open ...

  6. win7 设置双屏壁纸

    http://dualmonitortool.sourceforge.net/ http://www.displayfusion.com/Features/Wallpaper/ 以第一个软件为例: 1 ...

  7. 剑指offer——35二叉树的后序遍历

    题目描述 输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历的结果.如果是则输出Yes,否则输出No.假设输入的数组的任意两个数字都互不相同.   题解: 这道题,一开始以为将后序遍历排序后的得 ...

  8. 好文 | MySQL 索引B+树原理,以及建索引的几大原则

    Java技术栈 www.javastack.cn 优秀的Java技术公众号 来源:小宝鸽 blog.csdn.net/u013142781/article/details/51706790 MySQL ...

  9. uoj213 【UNR #1】争夺圣杯

    题目 设\(f_i\)表示所有长度为\(i\)的区间的最大值的和,求\(\bigoplus \sum_{i=1}^nf_i\) 不难发现随机数据非常好做 由于一个随机序列的前缀最大值期望只会变化\(\ ...

  10. 字符串KMP算法

    讲解:http://blog.csdn.net/starstar1992/article/details/54913261 #include <bits/stdc++.h> using n ...