여러 가지 타입을 한 가지 타입으로 처리하는 기술로 부모 클래스 타입의 참조 변수로 자식 클래스의 인스턴스를 참조할 수 있다.
하나의 클래스 영역 내에서 이름이 같은 메소드를 여러개 정의할 수 있다.
동일한 기능을 수행하는 메소드가 전달값을 각각 다르게 받아서 구동되는 경우 매번 메소드 이름을 다르게 작성하는 것보다 훨씬 더 프로그램 가독성을 좋게 할 수 있다.
EX1)
public class OverloadingPractice {
public void getNum(int num1){
//OverloadingPractice.getNum(3);
}
public void getNum(float num1){
//OverloadingPractice.getNum(2.3);
}
public void getNum(int num1, int num2){
//OverloadingPractice.getNum(3 ,5);
}
}
동일한 메소드의 오버로딩 개수를 줄일 수 있다.
public class Poly{
public static void main(String[] args){
Washer w= new Washer();
w.wash(new Window());
w.wash(new Tire());
}
}
class Car{
protected int minute;
public Car(int minute){ this.minute = minute; }
}
class Window extends Car{
public Window(){ super(10); }
@Override
public String toString(){ return "Window"; }
}
class Tire extends Car{
public Tire(){ super(30); }
@Override
public String toString(){ return "Tire"; }
}
class Washer{
public void wash(Car c){
System.out.println(c + "청소 시간 : " + c.minute);
}
}
바인딩
메소드에 대한 호출과 실제 구현된 메소드의 코드와 연결되는 것
정적 바인딩
객체의 타입이 컴파일러에 의해 컴파일되는 시점에 결정되는 것
private, final, static
동적 바인딩
객체의 타입이 실행 중에 결정되는 것
상속관계에 오버라이딩된 메소드
Parent p = new Child;
p.display(); //컴파일시에는 정적바인딩, 실행시에는 동적바인딩됨
//Sonata 클래스는 Car 클래스의후손
Car c= new Sonata();
//Sonata클래스형에서Car클래스형으로바뀜
//Sonata 클래스는 Car 클래스의후손
Car c= new Sonata();
((Sonata)c).moveSonata(); //다운 캐스팅
현재 참조형 변수가 어떤 클래스 형의 주소를 참조하고 있는지 확인할 때 사용하는 연산자로 클래스 타입이 맞으면 true, 맞지 않으면 false 반환