如何使用Arrays.copyOf()对数组扩容,使用数组实现栈

栈是一种容器,对栈的操作有pop()出栈,就是从栈中取出栈顶元素,push()入栈,将元素压入栈顶,peek(),返回栈顶元素(但是不出栈)

这里使用数组实现,初始时刻,默认栈的大小是2,每次入栈之前先判断元素增加一个之后,栈的容量是否够用,如果不够用就用Arrays.copyOf();进行扩容;

对于Array.copy(E[] e,newLength);

其第一个形参指的是需要扩容的数组,后面是扩容后的大小,其内部实现其实是使用了System.arrayCopy();在内部重新创建一个长度为newLength 类型是E 的数组

并返回该数组的引用;

后面附上测试代码:

package com;

import java.util.Arrays;

//如何使用数组实现栈
class MyStack<E>
{
	 
	private E[] stack;
	private int size;
	
	public int getSize() {
		return size;
	}

	public void setSize(int size) {
		this.size = size;
	}

	//构造函数
	public MyStack()
	{   
		   //初始时候的数组的容量是2
		   stack = (E[]) new Object[2];
		   
	}

	 //判断栈是否为空
	public boolean isEmpty()
	{
		   return size==0;
	}
 //返回栈顶元素 但是不出栈 
	public  E peek()
	{
		if(size == 0)
		{
			 return null;
		}
		else
		{  
			 System.out.println("栈顶元素---》"+stack[size-1]);
			 return   stack[size-1];
	       
		}
	}
	
	//出栈  返回栈顶元素并且将size-1;并且将栈顶元素赋值为null
	public  E pop()
	{
		     E  value = peek();
		     if(value!=null)
		     {
		    	  stack [size-1] =null; 
		    	 size -=1;
		     }
		     System.out.println("正在出栈"+value);
		     return value;
	}
	
	//入栈 并返回入栈的值
	public E push(E e)
	{
		   ensureSize(size+1);   //先判断 如果增加一个值之后 数组的大小是不是够用;
		   stack [size++] = e;   //把新的值放到最后,并且把元素的数量size 加一  ; 表示
		   System.out.println("正在入栈--》"+e);
		   return e;
		   
	}
	//判断容器的大小 如果不够就要扩容
	 private void ensureSize(int size)
	 {
		   int length = stack.length;
		 
		   //如果元素的数量超过数组的容量,就需要对栈进行扩容
		   if(size>length)
		   {
			     int newLength = 10+length;
			     stack = Arrays.copyOf(stack, newLength); //这里的数组扩充用Arrays.Copy() 另外一个System.arrayCopy();
			     System.out.println("正在扩充数组的容量----->"+stack.length);
		   }
	 }
	
}

public class Main2
{
	
	 public  static void main(String [] args)
	 {
		 
		 MyStack <String>  stack = new MyStack<String>();
		    System.out.println(stack.peek());
		    
		    stack.push("hello");
		    stack.push("你好");
		    
		    stack.push("我也好");
		    stack.peek();
		    stack.pop();
		    stack.pop();
		    stack.pop();
		    stack.pop();
	 }

}


  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Arrays.copyOf() 和 System.arraycopy() 都是用于数组的复制操作,但它们有一些不同之处。 Arrays.copyOf() 方法是在 Java 1.6 版本中引入的,它用于创建一个新的数组,并将源数组中的元素复制到新数组中。该方法具有以下两种重载形式: 1. copyOf(original, newLength):将原始数组的前 newLength 个元素复制到新数组中。如果新长度小于原始数组的长度,则新数组将被截断;如果新长度大于原始数组的长度,则新数组将被填充默认值。 2. copyOf(original, newLength, newType):与上述方法相似,但可以指定新数组的类型。 示例使用 Arrays.copyOf() 方法: ```java int[] original = {1, 2, 3, 4, 5}; int[] copy1 = Arrays.copyOf(original, 3); // 复制原数组的前三个元素 int[] copy2 = Arrays.copyOf(original, 7); // 复制原数组的所有元素,并用默认值填充额外位置 ``` System.arraycopy() 方法是在 Java 1.0 版本中引入的,它也用于将源数组中的元素复制到目标数组中。该方法的语法如下: ```java System.arraycopy(src, srcPos, dest, destPos, length); ``` 其中,src 是源数组,srcPos 是源数组中要开始复制的起始位置,dest 是目标数组,destPos 是目标数组中要开始粘贴的起始位置,length 是要复制的元素个数。 示例使用 System.arraycopy() 方法: ```java int[] src = {1, 2, 3, 4, 5}; int[] dest = new int[5]; System.arraycopy(src, 0, dest, 0, 5); // 复制 src 数组的所有元素到 dest 数组中 ``` 总结来说,Arrays.copyOf() 方法提供了更简洁的方式来复制数组,并且可以轻松地截取或填充数组。而 System.arraycopy() 方法则提供了更灵活的复制方式,可以指定复制的起始位置和复制的元素数量。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值