public class MYSQLDBMain {
public static void main(String[] args) {
MYSQLDB my = new MYSQLDB();
my.sqlQuery();//0.exit를 선택하기 전까지 무한반복
} }
일단 위의 코드는 main() 함수이다.
main() 함수는 자바 가상 머신이 프로그램 시작을 위해 호출하는 함수로, 클래스 내부에 만들지만 클래스의 메서드는 아니다.
여기에서 메서드란 무엇일까.
(나는 자바왕초보이기에, 메서드가 무엇인지 알아봐야한다..)
메서드란 자바 프로그램에서 클래스 내부의에 사용되는 함수를 뜻한다.
즉 메서드는 함수에 객체 지향 개념이 포함된 용어이다.
public class Stu{
String Stuname;
public String getStuName() {
return Stuname;
}
}
이 코드에서 메서드는 getStuName이다.
메서드는 객체 지향 개념이 포함된 용어라고 정의했다.
흔히 자바는 객체 지향 언어라고도 많이 알려져 있는데, 객체 지향의 의미는 무엇일까?
객체 지향 프로그래밍이란 프로그래밍에서 필요한 데이터를 추상화시켜 상태와 행위를 가진 객체를 만들고 그 객체들 간의 유기적인 상호작용을 통해 로직을 구성하는 프로그래밍 방법이다.
(장점)
(단점)
클래스: 어떤 문제를 해결하기 위한 데이터를 만들기 위해 추상화를 거쳐 집단에 속하는 속성과 행위를 변수와 메서드로 정의한 것으로 객체를 만들기 위한 메타정보라고 볼 수 있다.
인스턴스(객체) : 클래스에서 정의한 것을 토대로 실제 메모리에 할당된 것으로 실제 프로그램에서 사용되는 데이터
추상화는 추상 클래스나 추상 클래스가 갖는 추상 메서드를 의미하기보다는 클래스를 설계하는 것 자체를 의미한다.
즉, "공통의" 속성이나 기능을 묶어 이름을 붙이는 것이다.
캡슐화의 목적 2가지
객체 지향 프로그래밍에서는 캡슐화를 통해 객체가 외부에 노출하지 않아야할 정보 또는 기능을 접근제어자를 통해 적절히 제어 권한이 있는 객체에서만 접근하도록 할 수 있기에 코드의 수정이 일어났을 때 책임이 있는 객체만 수정하면 되기에 영향 범위를 예측하는데 수월하다.
뿐만 아니라 관련된 기능과 특성을 한 곳에 모으고 분류하기 때문에 객체 재활용이 원활하다.
객체 지향 프로그래밍에서 기능과 특성의 모음을 "클래스"라는 "캡슐"에 분류해서 넣는것이 캡슐화다.
상속은 부모클래스의 속성과 기능을 그대로 이어받아 사용할 수 있게하고 기능의 일부분을 변경해야 할 경우 상속받은 자식클래스에서 해당 기능만 다시 수정(정의)하여 사용할 수 있게 하는 것이다.
하나의 변수명, 함수명 등이 상황에 따라 다른 의미로 해석될 수 있는 것이다.
즉 오버라이딩(Overriding), 오버로딩(Overloading)이 가능하다는 얘기다.
오버라이딩 : 부모클래스의 메서드와 같은 이름, 매개변수를 재정의 하는것.
오버로딩 : 같은 이름의 함수를 여러개 정의하고, 매개변수의 타입과 개수를 다르게 하여 매개변수에 따라 다르게 호출할 수 있게 하는 것.
getter, setter를 사용하면 메서드를 통해서 접근하기 때문에, 메서드 안에서 매개변수같이 어떤 올바르지 않은 입력에 대해 사전에 처리할 수 있게 제한하거나 조절할 수 있다.
예를들면 setter에서 유효범위를 넘은 정수가 들어왔을 때의 처리를 하고나서 set하거나 예외처리를 해버릴 수 있는 것이다.
getter도 마찬가지로 굳이 예를들자면 자료에 무언가 더하거나 빼고 준다든지가 가능하다.
public class MYSQLDBMain {
public static void main(String[] args) {
MYSQLDB my = new MYSQLDB();
my.sqlQuery();//0.exit를 선택하기 전까지 무한반복
} }
위의 코드를 분석하다가 여기까지 오게 되었는데 내가 궁금했던 것은
MYSQLDB my = new MYSQLDB();
부분이었다.
MYSQLD는 다른 클래스명인데 이 뒤의 my는 왜 붙었으며, new은 왜 꼭 정의해주어야 할까?
MYSQLDB my = new MYSQLDB(); my.sqlQuery();
이 코드는 MYSQLD 클래스 자료형으로
my 변수를 선언하고 new MYSQLDB();로 MYSQLD 클래스를 생성하여 my에 대입한다는 뜻이다.
이때, my를 참조 변수라고 하고, 이 변수가 생성된 인스턴스를 가리킨다.