Test109~Test113
추상클래스(Abstract)는 선언만 있고 정의가 없는 하나 이상의 메소드(추상 메소드)를 갖는 클래스로 하위 클래스에서 오버라이딩(Overrideing)할 것으로 예상되는 메소드에 대해 메모리 낭비 없이 미리 호출 계획을 세워두기 위해 만든다.
// 틀만 작성해 놓은 것!
[접근제어지시자] abstract class 클래스명
{
[접근제어지시자] abstract 자료형 메소드명([매개변수], ...);
}
클래스가 적어도 하나 이상의 추상 메소드를 포함할 때 그 클래스는 클래스 앞에 『abstract』 키워드를 붙여 추상 클래스로 명시해야 하며, 추상 클래스로 선언된 경우에는 불완전한 형태의 클래스이므로 객체를 생성할 수 없다.
클래스명 ob = new 클래스명(); <=== 이거 할 수 없어!
추상 메소드가 존재하지 않는 추상 클래스마저도 객체를 생설할 수 없는 것이다.
즉, 추상 클래스는 독립적으로 존재할 수 없기 때문에 상속을 위해서만 존재하며
추상 클래스에서 상속받는 하위 클래스에서는
반드시 추상 메소드를 오버라이딩(Overriding)해야 한다.
// 추상 클래스
abstract class SortInt111
{
private int[] value;
protected void sort(int[] value)
{
this.value = value;
sorting();
}
// 추상 메소드
protected abstract void sorting();
protected int dataLength()
{
return value.length;
}
// 『final』 키워드로 인해
// 이 클래스(SortInt111)를 상속받는 클래스에서
// 이 메소드를 재정의(Method Overriding)할 수 없다.
protected final int compare(int i, int j)
{
int x = value[i];
int y = value[j];
if(x==y)
return 0;
else if(x>y)
return 1;
else
return -1;
}
protected final void swap(int i, int j)
{
int temp = value[i];
value[i] = value[j];
value[j] = temp;
}
}
// Sort111(추상 클래스)를 상속받은 클래스 -> 일단은 추상 클래스
// -> 추상 메소드 『sorting()』을 Override -> 일반 정상 클래스
//public abstract class Test111 extends SortInt111
public class Test111 extends SortInt111
{
static int[] data = {7, 10, 3, 8, 7};
@Override //상속받은 데이터랭스, 컴페어, 스왑 들어가있음
//protected abstract void sorting();
protected void sorting(){
//selection sort
for(int i=0; i<dataLength()-1; i++){
for(int j=i+1; j<dataLength(); j++){
// 크기비교
if(compare(i,j)>0)
{
// 자리바꿈
swap(i,j);
}
}
}
}//end sorting
public static void main(String[] args)
{
//SortInt111 ob = new SortInt111();
//Test111 ob = new Test111();
//추상클래스이기 때문에 안됨~!
Test111 ob = new Test111();
System.out.print("Source Data : ");
for (int n : data)
System.out.printf(n + " ");
System.out.println();
ob.sort(data);
System.out.print("Sorted Data : ");
for (int n : data)
System.out.printf(n + " ");
System.out.println();
}
}
/* 실행 결과
Source Data : 7 10 3 8 7
Sorted Data : 3 7 7 8 10
계속하려면 아무 키나 누르십시오 . . .
*/