본문 바로가기

JAVA

(158)
(collection framework의) Stack ## 스택(Stack) // - 데이터를 후입선출(LIFO, Last-In-First-Out) 방식으로 저장하고 관리 // - 주로 데이터의 역순으로 처리하는 상황에서 유용하게 사용됨 // - 보통 반복문을 돌리지는 않음 /# 특징: // // 1. 후입선출 (LIFO): // - 가장 마지막에 추가된 요소가 가장 먼저 제거됩니다. // - 이러한 특성은 주로 재귀 함수 호출, 뒤로가기 버튼, 실행 취소 기능 등과 같이 역순으로 처리해야 하는 상황에서 유용합니다. // // 2. 요소 추가 및 제거: 스택은 주로 push (요소 추가)와 pop (요소 제거) 연산을 통해 데이터를 관리합니다. // // 3. 한쪽 끝에서 추가 및 제거: 요소는 보통 스택의 한쪽 끝에서 추가되고 제거됩니다. // --> 마..
TypeCasting AAA a1 = new BBB();// 우리는 이렇게 쓸일이 거의 없다. 쓸 수는 있다고! a1.testA();// 출력 : A의 매서드 BBB b1 = (BBB)a1; // 원래는 BBB b = a; 이거안되는데, 강제로 type casting해준거임 // (부모의 참조변수를 가져올때는 댓가가 필요하다구.) // BBB b1 = new BBB();--> b1.testB();// 출력 : B의 매서드 b1.testA();// 출력 : A의 매서드 // BBB b1 = new BBB();와 BBB b2 = (BBB) a;의 경우 // 모두 BBB 클래스의 객체를 가리키는 것이므로 BBB 클래스의 모든 메서드와 속성을 호출할 수 있다! // --> BBB객체를 a1으로 받아서 다시 b1에 넘겨주는게 그냥 B..
Polymorphism package p7; public class Main_polymorphism { public static void main(String[] args) { // 다형성 : 참조변수는 본인의 타입을 포함해서 모든 자손을 받을 수 있다. // 1. 일반적인 경우 AAA a = new AAA(); a.printA(); BBB v1 = new BBB(); BBB v2 = null;// 참조 주소에 null을 넣을 수 있으니까는~ // BBB b2 = new AAA();--> 이건 당연히 안되겠지. type mismatch double d = 1;// 이것도 type mismatch인데, 자동으로 type casting이된거임. // 2. 다형성의 경우 AAA aaa; aaa = new AAA();// 당연히 되는..
Basic // 어떠한 직업군들에 대한 클래스를 여러개 생성한다 // 이름, 나이라는 인스턴스가 계속 공통적으로 들어가지 class Person{ String name; int age; } class Student extends Person{ // --> 상속하는 클래스와 같은명의 변수를 안써도됨! (쓰면 오히려 머리아파..) //String name; //int age; int score; } class PoliceMan extends Person{ //String name; //int age; String grade; } class Lecture{ String name; int age; int career; }
Final package p4; public class Main_example { public static void main(String[] args) { BBB b1 = new BBB(10);// 출력 : AAA의 기본 생성자, BBB의 int생성자 // 부모클래스의 기본생성자가 딸려온다! // if) super로 정의해주게되면 AAA의 int생성자, BBB의 int생성자가 출력된다. } } /*final*/ class AAA{ // class에도 final을 붙일 수 있다 // --> 이렇게되면 AAA는 누구에게도 상속해주지 못하는 클래스가 되는거임 // --> 나는 안쓸걸.... int v1; int v2; AAA(){ // 부모클래스의 기본 생성자는 없으면 안돼! 상속받는애가 생성자를 못만든다구 System..
Super package p3; public class Main_super { public static void main(String[] args) { // AAA a = new AAA(); BBB b = new BBB();// --> AAA의 생성자, BBB의 생성자아아ㅏ아 두개다 호출됨! // b.v2 ----> BBB의 변수임!!!.... 이렇게하지마세요~!~! b.test1();// --> 이것은 AAA의 메서드10 b.test2();// --> 이것은 BBB의 메서드20 System.out.println(b.v2);// 20 } } class AAA{ int v1; int v2; AAA (){ System.out.println("AAA의 기본 생성자"); } AAA(int v1){ this.v1 =v1; ..
Interface Basic // 상속 + 다형성 + 오버라이딩 ---> 인터페이스! // 코드의 의도 : 결합도를 낮춘다 (너무 많이 의존하지 않도록) // --> 하나의 모듈을 변경할 때 다른 모듈에 미치는 영향을 최소화하고 버그를 줄이는 데 도움이됨 // --> 모듈 간의 강한 결합이 없으면 해당 모듈을 다른 프로젝트에서 더 쉽게 재사용할 수 있음 // --> 각 모듈이 독립적으로 작동하고 목적을 명확하게 수행할 때 코드를 이해하기 쉬워짐 class AAA{ int a1; int a2; void test1() { System.out.println("이것은 test1의 메서드"); } } // 상속 문법 : ~ extends + 상속받을 클래스명 class BBB extends AAA { int b1; int b2; } clas..
Collection Framework // 주요 컬렉션 프레임워크 인터페이스 및 클래스: // List: '순서가 있는' 요소를 저장하는 컬렉션. // 중복된 요소를 허용하며, 인덱스를 통해 요소에 접근할 수 있습니다. // ex) ArrayList, LinkedList, Vector 등 // Set: 중복된 요소를 허용하지 않는 컬렉션. (순서x) // ex) 예를 들어, HashSet, LinkedHashSet, TreeSet 등 // Map: 키-값 쌍을 저장하는 컬렉션. (순서x) // 각 키는 유일해야 하며, 키를 통해 값을 검색합니다. // ex) HashMap, LinkedHashMap, TreeMap 등 // Queue: 큐 자료 구조를 구현하는 컬렉션. // 주로 FIFO(First-In-First-Out) 순서를 따릅니다...