Stack ==> 후입선출(LIFO)의 자료구조
Queue ==> 선입선출(FIFO)의 자료구조

Stack의 명령
1. 자료 입력 : push(입력값)
2. 자료 출력 : pop() ==> 자료를 꺼내온 후 꺼내온 자료를 Stack에서 삭제한다.
                     peek() ==> 삭제없이 자료를 꺼내온다./ 데이터를 꺼내왔을때 내가 출력하고 싶은 데이터인지 확인
package kr.or.ddit.basic;

import java.util.LinkedList;
import java.util.Queue;
import java.util.Stack;

public class stackQueueTest {
	/*
	 	Stack ==> 후입선출(LIFO)의 자료구조
	 	
	 	Queue ==> 선입선출(FIFO)의 자료구조
	 */

	public static void main(String[] args) {
		/*
		 	Stack의 명령
		 1. 자료 입력 : push(입력값)
		 2. 자료 출력 : pop() ==> 자료를 꺼내온 후 꺼내온 자료를 Stack에서 삭제한다.
		 			 peek() ==> 삭제없이 자료를 꺼내온다./ 데이터를 꺼내왔을때 내가 출력하고 싶은 데이터인지 확인
		 */
			Stack<String> stack = new Stack<String>();
			
			stack.push("홍길동");
			stack.push("일지매");
			stack.push("변학도");
			stack.push("강감찬");
			
			System.out.println("현재 stack값 : " + stack);
			
			String data = stack.pop();
			System.out.println("꺼내온 값 : " + data);
			System.out.println("꺼내온 값 : " + stack.pop());
			System.out.println("현재 stack 값 : " + stack);
			
			stack.push("성춘향");
			System.out.println("추가 후 stack 값 : " + stack);
			
			System.out.println("꺼내온 값 : " + stack.pop());
			System.out.println("현재 stack 값 : " + stack);
			
			System.out.println("삭제없이 꺼내온 값 : " + stack.peek());
			System.out.println("현재 stack 값 : " + stack);
			
			System.out.println("---------------------------------------");
Queue의 명령
1. 자료 입력 : offer(입력값)
2. 자료 출력 : poll() ==> 자료를 꺼내오고 꺼내온 자료를 Queue에서 삭제한다.
                     peek() ==> 삭제없이 자료를 꺼내온다.
Queue<String> queue = new LinkedList<String>();
			
			queue.offer("홍길동");
			queue.offer("일지매");
			queue.offer("변학도");
			queue.offer("강감찬");
			
			System.out.println("현재의 queue 값 : " + queue);
			
			String temp = queue.poll();
			System.out.println("꺼내온 값 : " + temp);
			System.out.println("꺼내온 값 : " + queue.poll());
			System.out.println("현재 queue 값 : " + queue);
			
			queue.offer("성춘향");
			System.out.println("현재 queue 값 : " + queue);
			
			System.out.println("꺼내온 값 : " + queue.poll());
			System.out.println("현재 queue 값 : " + queue);
			
			System.out.println("삭제없이 꺼내온 값 : "+ queue.peek());
			System.out.println("현재 queue 값 : " + queue);
			
	}

}

'JAVA 복습 & 정리' 카테고리의 다른 글

[HighJava] ListSort  (0) 2022.12.20
[HighJava] Stacktest  (1) 2022.12.20
[HighJava] ArrayListTest04  (0) 2022.12.20
[HighJava] ArrayListTest03  (0) 2022.12.20
[HighJava] ArrayListTest02  (0) 2022.12.20

+ Recent posts