专栏名称: java那些事
分享java开发中常用的技术,分享软件开发中各种新技术的应用方法。每天推送java技术相关或者互联网相关文章。关注“java那些事”,让自己做一个潮流的java技术人!《java程序员由笨鸟到菜鸟》系列文章火热更新中。
目录
相关文章推荐
芋道源码  ·  告警:MyBatis-Plus中慎用@Tra ... ·  11 小时前  
芋道源码  ·  Spring Boot + URule ... ·  2 天前  
51好读  ›  专栏  ›  java那些事

图解Java常用数据结构

java那些事  · 公众号  · Java  · 2019-01-02 16:00

正文

请到「今天看啥」查看全文


扩容

一般默认容量是10,扩容后,会length*1.5。

remove(E)

循环遍历数组,判断E是否equals当前元素,删除性能不如LinkedList。

3. Stack

Stack是经典的数据结构,底层也是数组,继承自Vector,先进后出FILO,默认new Stack()容量为10,超出自动扩容。

push(E)

pop()

4. 后缀表达式

Stack的一个典型应用就是计算表达式如 9 + (3 - 1) * 3 + 10 / 2,计算机将中缀表达式转为后缀表达式,再对后缀表达式进行计算。

中缀转后缀

  • 数字直接输出

  • 栈为空时,遇到运算符,直接入栈

  • 遇到左括号, 将其入栈

  • 遇到右括号, 执行出栈操作,并将出栈的元素输出,直到弹出栈的是左括号,左括号不输出。

  • 遇到运算符(加减乘除):弹出所有优先级大于或者等于该运算符的栈顶元素,然后将该运算符入栈

  • 最终将栈中的元素依次出栈,输出。

计算后缀表达

  • 遇到数字时,将数字压入堆栈

  • 遇到运算符时,弹出栈顶的两个数,用运算符对它们做相应的计算, 并将结果入栈

  • 重复上述过程直到表达式最右端

  • 运算得出的值即为表达式的结果

5. 队列

与Stack的区别在于:Stack的删除与添加都在队尾进行,而Queue删除在队头,添加在队尾。

ArrayBlockingQueue

生产消费者中常用的阻塞有界队列,FIFO。

put(E)

put(E) 队列满了


final ReentrantLock lock = this . lock ;
lock .lockInterruptibly();
try {
while






请到「今天看啥」查看全文