저번 시간에는 Generic을 사용하는 이유에 대해 자세하게 살펴보았다. 하지만 Generic은 너무 딱딱하다. 하나의 타입을 정의해놓으면 그 타입 외에는 어떠한 요소도 들어올 수 없다. 상속을 받더라도 마찬가지이다. 이러한 동작은 리스코프 치환원칙에 위배되는 설계이다. 상위 타입이 하는 일을 제대로 수행할 수 없기 때문이다. 자바는 이러한 문제에 대해서도 해결책을 갖고 있다. 한정적 와일드 카드 타입 Stack 클래스를 한 번 살펴보자 public class Stack { public Stack(); public void push(E e); public E pop(); public boolean isEmpty(); } 여기에 모든 원소를 스택에 넣는 메서드를 추가해보자 public void pushAl..
finally 블록 finally 블록은 보통 예외의 발생 여부와 상관없이 꼭 실행되어야 할 코드를 이 블록에 넣어 마지막에 출력하도록 처리한다. try { // 예외 처리가 발생할 가능성이 있는 로직 작성 } catch (Exception e) { // 예외 발생시 실행되는 로직 보통 에러 메시지를 출력 } finally { // 예외 발생 여부와는 상관없이 수행되는 로직 // finally 블럭은 try-catch문 마지막에 위치해야 함 } 예외 발생 시 try -> catch -> finally 순, 예외가 발생하지 않았을 땐 try -> finally 순으로 실행된다. 예제를 살펴보자 package exception; public class FinallyEx1 { public static void..
- Total
- Today
- Yesterday
- DB
- 취준
- DevOps
- 코딩
- 게시판
- Redis
- Spring
- 취업
- thread
- 면접 준비
- 면접준비
- 프로젝트
- docker
- 프로그래밍
- MySQL
- swarm
- 취업준비
- 백엔드
- 면접
- 개발자
- IT
- 동시성
- CS
- 코드
- 인터뷰
- Kotlin
- 자바
- java
- JPA
- 개발
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |