Java基础 - 栈

栈 (stack)又称堆栈,只允许在表的一端进行加入数据(push)和移除数据(pop)。因而按照 后进先出(LIFO, Last In First Out) 的原理运作。通常称能够进行插入、删除运算的一端为栈顶(Top),另一端称为栈底(Bottom)。当表中没有元素的时候称为空栈。

空栈时最先插入的元素总被放在栈的底部,只有所有元素被移除(弹出)后,它才能被删除

栈的存储结构有顺序存储结构和链式存储结构两种。在顺序栈中,可以考虑栈的上溢;在链式栈中,不必考虑栈的上溢,只需要考虑栈的下溢

栈的上溢是一种出错状态,应该设法避免;而下溢则是正常现象,可作为程序控制转移的条件

顺序栈

顺序栈 常用一维数组来实现

Java代码实现:

public class MyStack {
   
    private int[] storage;//存放栈中元素的数组
    private int capacity;//栈的容量
    private int count;//栈中元素数量
    private static final int GROW_FACTOR = 2;

    //不带初始容量的构造方法。默认容量为8
    public MyStack() {
   
        this.capacity = 8;
        this.storage=new int[8];
        this.count = 0;
    }

    //带初始容量的构造方法
    public MyStack(int initialCapacity) {
   
        if (initialCapacity < 1)
            throw new IllegalArgumentException("Capacity too small."
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据你提供的引用内容,我可以为你提供一个关于Java技术的简要介绍。请注意,在回答中我将引用和。 Java技术是指Java开发过程中所涉及的各种技术和工具。它包括了Java基础、设计模式、正则表达式、内存模型和垃圾回收算法、锁以及并发容器的源码、线程池源码、Web方面的技术和Spring框架、Spring AOP等内容。 在Java基础方面,我们可以学习算法和排序算法、二叉查找树、红黑树、B树、LSM树等数据结构和算法应用,还有BitSet解决数据重复和是否存在等问题。此外,还可以了解字符串常量池、字符串KMP算法、equals和hashcode、泛型、异常、反射等内容。 在设计模式方面,我们可以学习单例模式、工厂模式、装饰者模式、观察者设计模式和ThreadLocal设计模式。 正则表达式是Java中常用的模式匹配工具,我们可以学习捕获组和非捕获组、贪婪模式和勉强模式等。 Java内存模型和垃圾回收算法是Java开发中非常重要的一部分,我们可以学习Java内存模型的概念以及垃圾回收算法的原理。 并发编程是Java开发中必不可少的一部分,我们可以学习synchronized和volatile关键字的理解,以及锁和并发容器的源码实现。 在Web方面,我们可以学习SpringMVC的架构设计,包括解决servlet开发中的问题、各个组件的作用、DispatcherServlet、容器和组件之间的关系,以及SpringBoot的使用。 此外,我们还可以学习Spring AOP的源码,了解Advice接口及其实现类的定义和使用。 总之,Java技术是非常广泛的,包括了各种核心概念、工具和框架,有助于我们更好地进行Java开发。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值