フルスタックプロシージャ13 Java
2022.3.24.(首)
抽象化
インタフェース
Static
1.抽象化
1-1. 継承性と多様性の必要性
- 상속성은 객체 간의 공통적인 기능을 관리하기 위한 기법으로
코드의 재사용을 통하여 프로그램의 유지보수를 편리하게 한다.
- 다형성( Override, Overload )은 서로 다른 기능이지만
메서드의 이름을 공통되게 처리함으로써 전체 프로그램의
일관성을 유지하게 한다.
1-2. Override処理で問題が発生する可能性があります- '@Override' 키워드를 사용하지 않고 메서드를 재정의 하는
과정에서 메서드 이름에 실수가 발생하더라도 에러가 아닌
새로운 메서드의 정의로 인식되므로 의도하지 않은 실행결과를
가져올 수 있다.
- '@Override' 키워드를 사용하더라도 자식 클래스를 구현하는
개발자의 실수로 인하여 부모의 기능을 재정의 하지 않았다면
다형성의 구현은 이루어지지 않게 된다.
1-3. 継承処理時にoverrideを強制する- 추상화 기법은 특정 클래스를 상속받은 경우, 부모의 특정
메서드들을 무조건 재정의하도록 강제하는 기법이다.
- 특정 메서드를 재정의하도록 강제함으로써, 자식 클래스들을
작성하기 위한 가이드의 역할을 할 수 있다.
- 즉, 추상화 기법은 java 클래스를 작성하기 위한 설계도를
소스코드 형태로 제시하는 역할을 한다.
1-4. 抽象メソッドの作成- 추상 메서드를 정의하기 위해서는 'abstract' 키워드를
사용하여 메서드를 정의한다.
- 추상 메서드를 자식 클래스가 구현해야 하는 메서드의
가이드라인만 제시하기 위한 목적으로 사용되기 때문에,
선언만 가능하고 구현부가 없다.
// 일반 메서드
public void sayHello( ); {
... 구현부 ...
};
// 추상 메서드
// 선언만 가능하고, 구현부를 위한 블록이 존재하지 않는다.
public abstract void sayHello( );
1-5. 抽象メソッドを含むクラス- 추상 메서드를 하나 이상 포함하고 있는 클래스는 반드시
'추상 클래스'로 정의되어야 한다.
- 추상 클래스 'abstract' 키워드를 사용하여 정의할 수 있다.
// 추상 클래스의 정의
public abstract class Hello {
public abstract void sayHello( );
}
- 추상 클래스는 객체를 생성할 수 없고, 반드시 상속을 통해서만 사용될 수 있다.
즉, 추상 클래스는 다른 자식 클래스를 위한 '가이드라인'의 역할을 한다.
<抽象メソッドsayHelloを含む抽象クラスHello>
<抽象メソッドのOverride>
1-6. 汎用機能と設計提案の処理
- 추상 클래스는 생성자, 멤버변수, 일반 메서드 등을 포함할 수 있다.
- 즉, 공통 기능과 가이드라인을 모두 정의하여 다른 클래스에게 상속된다.
public abstract class Hello {
// 멤버변수 선언
private String msg;
// 생성자
public Hello( String msg ) { this.msg = msg; }
// 일반 메서드
public String getMsg( ) { return this.msg };
public void setMsg( String msg ) { this.msg = msg; }
// 선언만 되고, 구현부를 위한 블록이 존재하지 않는다.
public abstract void sayHello( );
}
<親デバイス(抽象メソッドを含む)
<抽象メソッドを超えたサブクラスArmy>
<抽象メソッドを超えたサブクラスNavy>
<抽象メソッドを超えたサブクラスAirForce>
<抽象メソッドの例の実行値>
2.インタフェース
public abstract class Unit {
public abstract void attack( ); // 공격
public abstract void shield( ); // 방어
public abstract void walk( ); // 걷기
public abstract void run( ); // 뛰기
public abstract void jump( ); // 점프
public abstract void pickup( ); // 아이템 줍기
}
- 추상 클래스인 Unit의 기능을 용도별로 분할하여 나누어 놓고,
주인공과 몬스터가 각각의 기능 중에서 자신에게 필요한 것들만
상속 받도록 하는 방법을 필요로 한다.
2-1. 抽象クラスの制限- 자바 클래스 간의 상속에서는 하나의 부모만 존재할 수 있기 때문에,
앞의 상황에서 요구하는 다중 상속의 구현은 불가능하다.
2-2. インタフェースとは?- 완벽한 추상화를 구현하기 위한 java Class의 한 종류이다.
- 다중 상속이 가능하기 때문에 용도별로 세분화 하여 필요한 요소만 상속할 수 있다.
추상 클래스
-> 멤버변수, 생성자, 메서드, 추상 메서드를 포함할 수 있다.
-> 이 클래스를 상속받는 자식 클래스는 다른 클래스를 상속받을 수 없다.
-> 객체의 생성이 불가능하다.
인터페이스
-> 추상 메서드만 포함할 수 있다.
-> 인터페이스는 다중 상속이 가능하다.
-> 객체의 생성이 불가능하다.
<インタフェースを作成する理由:継承のために汎用メソッドを作成するか、実行する操作をインタフェースとして使用します>
2-3. インタフェース継承implementsキーワード
- 인터페이스의 상속은 implements 키워드를 사용한다.
- 인터페이스도 추상화를 구현하고 있기 때문에, 인터페이스를 상속받는 클래스는
인터페이스 내의 모든 메서드들을 반드시 재정의 해야 한다.
<デバイスを継承するユーザクラス>
2-4. インタフェースマルチ継承
- 인터페이스는 콤마( , )로 연결하여 여러 개를 동시에 상속받을 수 있다.
public class Monster implements Fight, Move {
}
- 필요한 경우 다른 클래스와 동시에 상속받을 수 있다.
public class Monster extends User implements Fight, Move {
}
<インタフェースの例>
<ピック()メソッド付きActionInterface>
<攻撃()メソッドとシールド()メソッドを使用したFight Interface>
3. Static
// 하나의 게시물을 표현하기 위한 클래스
// 요청사항 : 전체 글 수, 카테고리 정보
public class Article {
private int count; // 전체 글 수
private String category; // 카테고리
private int num; // 글 번호
private String title; // 제목
private String regDate; // 날짜
}
- 멤버변수는 모든 객체가 독립적으로 가지는 고유 데이터이기 때문에
게시물의 수라는 공유 데이터를 모든 게시물이 갖게 된다.
- 즉, 각각의 객체가 중복된 데이터를 갖게 된다.
3-1. オブジェクト間の共有リソースを表す静的キー- 클래스를 설계할 때, 멤버변수 중 모든 객체에서 공통적으로 사용해야 하는 값에
static을 붙인다.
public class Article {
private static int count; // 전체 글 수
private static String category; // 카테고리
private int num; // 글 번호
private String title; // 제목
private String regDate; // 날짜
}
- static이 붙은 멤버변수는 객체의 갯수에 상관 없이 단 하나만 생성되며,
이를 모든 객체가 공유하기 때문에 메모리를 효율적으로 사용할 수 있다.
<オブジェクト間でリソースを共有するための静的>
<静的使用後のモデル図>
3-2. コンピュータのメモリ構造
- 코드영역(고정 영역)
-> 프로그램의 코드가 저장되는 영역
이 영역에 저장된 명령어들을 CPU가 하나씩 가져가 실행한다.
- 데이터 영역(고정 영역)
-> 전역변수와 static으로 선언되는 변수가 할당된다.
이 영역에 할당되는 변수들은 프로그램 시작과 동시에 메모리 공간이 할당되어
종료될 때 까지 남아있게 된다.
- 힙 영역(동적 영역)
-> 프로그래머가 원하는 시점에 변수를 할당하고, 소멸시키는 영역
메모리 동적 할당시 사용된다. 객체가 생성되는 영역이다.
- 스택 영역(동적 영역)
-> 함수가 실행될 때 사용되는 파라미터와 지역변수에 대한 메모리 공간
함수의 종료와 함께 소멸된다.
3-3. プログラムが使用するメモリ領域- 고정 영역
-> 프로그램이 실행되면 실행 파일이 메모리에 로드되면서,
실행파일의 용량만큼 RAM을 사용한다.
-> 실행 파일의 크기는 변할 수 없으므로 이 영역의 크기는 고정 크기를 갖는다.
- 동적 영역
-> 프로그래머가 new 키워드를 사용해서 객체나 배열을 생성하면 사용된다.
( 힙 영역 )
-> 또 다른 경우는 메서드가 호출되는 동안 사용될 파라미터와 지역변수가
생성된다.( 스택 영역 )
-> 메서드가 종료되거나 객체가 더 이상 사용되지 않으면 생성된 변수나
객체는 메모리에서 사라지므로, 이 영역은 유동적인 크기를 갖게 된다.
3-4. 静的データの作成場所- static 데이터는 메모리의 고정 영역 중 데이터 영역에 생성되고,
일반 멤버변수나 객체는 동적 영역 중 Heap 메모리 영역에 생성된다.
3-5. プログラム使用メモリの順序- 최초 실행시 고정 영역에 실행 파일만큼의 메모리를 점유한다.
- 프로그램이 각종 동작을 수행하는 동안 동적 영역을 사용한다.
3-6. メンバー変数と静的メンバー変数の違い- static 변수는 프로그램의 실행과 동시에 객체의 생성 여부와 상관 없이
이미 존재하기 때문에 소스코드에서는 특정 클래스 안에 명시하지만,
그 클래스를 통해서 생성되는 객체나 그 안에 포함되는 멤버변수와는 다른 존재이다.
- 객체가 생성되지 않았더라도 이미 존재하고 있기 때문에 static 변수는 객체의
이름을 통해 접근하는 것이 아니라, 클래스의 이름을 통해서 접근해야 한다.
- 단, static 변수가 선언된 클래스 안에서는 변수 이름으로 직접 접근이 허용된다.
- Article 클래스 및 다른 클래스에서 접근하는 경우
Article.count = 9;
Article.category = "공지사항";
- Article 클래스에서 접근하는 경우
count = 15;
category = "Q&A게시판";
3-7. 静的変数と静的メソッド- 클래스에서 정의하는 일반 메서드들은 객체의 생성과 동시에
동적 메모리 영역에서 활성화 된다.
-> 동적 메모리 영역의 입장에서는 고정 메모리 영역의 자원들은 항상 존재한다.
-> 고정 메모리 영역의 자원들은 동적 메모리의 자원들이 항상 존재하는
것이라는 보장을 받지 못한다.
- 그러므로 객체의 생성과 상관 없이 static 변수에 접근하기 위한 메서드를
만들 필요가 있는데, 메서드의 정의 과정에서 static 키워드를 사용하면
static 자원에 접근하기 위한 메서드를 만들 수 있다.
public class Article {
private static int count;
public static void setCount( int count ) {
Article.count = count;
}
public static int getCount( ) {
return Article.count;
}
}
3-8. 静的メソッドの使用制限- 메모리 영역의 차이 때문에 static 메서드는 동적 메모리 영역의
멤버변수를 사용하거나, static이 아닌 일반 멤버함수를 호출할 수 없다.
고정 영역
-> static 변수와 static 멤버함수가 생성된다.
-> 이 영역의 자원들은 프로그램이 실행되는 동안 항상 존재한다.
-> 동적 메모리 영역의 자원들은 항상 존재하는 것이 아니기 때문에
static 멤버함수는 동적 메모리 영역의 멤버변수를 사용하거나,
static이 아닌 일반 멤버함수를 호출할 수 없다.
동적 영역
-> 객체, 객체 안의 멤버변수, 메서드, 메서드가 호출되었을 때 사용되는
지역변수 등이 생성된다.
-> 이 영역의 자원들은 생성과 제거가 유동적으로 반복된다.
-> static 자원은 항상 존재하는 것이므로 동적 영역에서는 static 변수를
활용하거나, static 멤버함수를 호출할 수 있다.
Reference
この問題について(フルスタックプロシージャ13 Java), 我々は、より多くの情報をここで見つけました https://velog.io/@doby98/풀스택-과정-day13Javaテキストは自由に共有またはコピーできます。ただし、このドキュメントのURLは参考URLとして残しておいてください。
Collection and Share based on the CC Protocol