classpath
자바 가상머신의 클래스 탐색 경로
새로운 폴더를 만들고 그 안에 클래스 파일을 옮겨 넣게 되면 그 클래스의
인스턴스를 생성하려고 할 때 경로를 찾지 못해 에러가 발생한다.
그래서 이 때 [경로를 찾을 수 있도록] claasspath를 설정 해야 한다.
set classpath
클래스 탐색 경로 설정
cmd(터미널)에서 **set classpath**명령어를 통해 새로 만든 폴더에 있는
파일의 경로를 찾을 수 있도록 설정 해주면, 정상적으로 클래스 파일을 찾아
그 클래스의 인스턴스를 생성할 수 있게된다.
cmd(터미널)에서 set classpath 실행 방법
set classpath=.; 뒤에 절대경로, 혹은 상대경로를 추가하면된다.
C:\PackageStudy>**`set classpath=**.;`C:\PackageStudy\MyClass
. (점): 현재디렉토리
;(세미콜론) 줘서 100개의 경로를 추가할 수 도 있다.
루트 디렉토리를 시작으로 지정한 절대 경로
C:\PackageStudy>set classpath=.;C:\PackageStudy\MyClass
클래스 패스를 절대 경로로 고정시키면?
**현재 디렉토리를 기준으로 지정한 ‘상대 경로’
C:\PackageStudy>set classpath=.;.\MyClass
. (점): 현재디렉토리
일반적으로 현재 디렉토리를 기준으로 경로를 지정한다.
이클립스를 새로 깔거나, 다른 곳에 옮겨서 사용하거나 파일을 옮기는 경우 등,
상위 폴더 자체의 경로가 변경 되는 경우가 있기 때문에, 절대 경로를 지정하면
경로를 찾지 못하는 상황이 당연히 발생하게 된다.
그렇기 때문에 일반적으로 상대 경로로 지정을 한다.
. -> 현재 디렉토리 / .. -> 이전 디렉토리
>cd . //현재 디렉토리로 이동
>cd.. //이전(한단계 상위) 디렉토리로 이동
>cd java_area //java_area로 이동
//cd (change directory) : 명령창의 디렉토리 변경(이동) 명령어
//위의 명령어, 옵션은 windows, linux 동일함
실제 업무에서는 자신이 만들지 않은 클래스 파일을 사용하는 경우가 많은데,
이 때 만들어진 클래스들의 이름이 겹치는 일이 충분히 발생할 수 있다.
기본적으로 같은 이름의 클래스 파일을 같은 폴더에 둘 수 없기 때문에
다른 package를 사용하면 같은 이름을 가진 클래스 파일을 사용해야 하는 경우
다른 폴더에 저장되기 때문에 별도로 관리할 수 있다.
공간: 동일 이름의 클래스 파일을 같은 위치에 둘 수 없다. // Circle.java 와 Circle.java
접근방법: 인스턴스 생성 방법에서 두 클래스에 차이가 없다. // Circl circle = new Circle();
공간적, 접근적 충돌 해결을 위한 패키지 선언
클래스 접근 방법의 구분
- 서로 다른 패키지의 두 클래스는 인스턴스 생성 시 사용하는 이름이 다르다.
// com.bit.Circle... 과 com.bat.Circle...
클래스의 공간적인 구분 - 서로 다른 패키지의 두 클래스 파일은 저장되는 위치가 다르다.
// com > bit > Circle.java 와 com > bat > Circle.java
기본적으로 회사의 도메인을 뒤에서부터 작성(www는 제외: 전세계 공통)하고
마지막은 팀 이름 또는 프로젝트 이름을 작성한다.
구분은 점(.)으로 한다.(폴더가 생성되는 단위)
예시) com.bit.class4 , com.oracle.팀 이름 o r프로젝트 이름 (www.oracle.com)
Java는 객체지향 언어! (반대는 절차지향 언어(c언어))**
객체지향 언어의 특징
1) 정보은닉 information hiding 2) 상속 inheritance
3) 다형성 polymorphism (중요! 70%) 4) 캡슐화 encapsulation
(+ 추상화 abstraction)
정보 은닉을 하지 않고 프로그램을 만들어 사용자에게 제공했을 때,
사용자가 클래스의 데이터에 직접적으로 접근했으나
(예를 들어 논리적 오류를 가진 값을 대입하는 등으로)
에러가 발생하지 않고(컴파일 오류가 발생하지 않고)프로그램이 실행되어
원래의 프로그램의 의도와 전혀 다른 결과가 도출되는 문제가 생길 수 있다.
(⇒이것은 프로그램을 잘못 만든 것이긴 함.)
이런 문제들을 방지하기 위해서 접근 제한자를 이용해 외부에서의 직접적인 접근 권한을 제한하고
기능(메소드)을 통해 간접적으로 접근하도록 유도하는 것이다.
(그래야 논리적 오류를 가진 값 등을 가지고 접근할 때 컴파일 오류로 이어지도록 만들 수 있다.)
정보은닉의 기본 원칙에 따라 인스턴스 변수는 public으로,
인스턴스 변수에 접근하기 위한 메소드 들은 public으로 선언하는 것이 관례이다.
public > protected > default > private
각각의 접근 제한자는 변수, 메소드, 클래스의 접근 권한을 제한하기 위해서 사용되며,
변수, 메소드, 클래스 **이름의 맨 앞에 해당 키워드를 붙여 사용한다.
(default는 아무것도 안붙임)
모든 파일에서 접근 가능, 어디서든 인스턴스 생성이 가능하다.
private으로 선언된 데이터를 외부에서 활용하기 위해
getter, setter 같은 함수를 public으로 선언해서 사용한다.
public 클래스는 **외부에 노출시키기 위한 클래스이다.
사용 예시: public static void main(String[] args){}
동일 패키지로 묶인 클래스 내에서만[(같은 패키지 내에서만)
접근이 가능하고, 인스턴스 생성을 허용한다.
이름 앞에 접근제한자를 붙이지 않으면] defalut이다.
= 아무 선언도 하지 않은것, [default는 키워드가 아니다.]
사용 예시: class Circle { ... } /
다른 패키지에 있더라도 상속받은 클래스에서는** 접근 가능하다. (아직 안배움)
같은 클래스 내에서만 접근 가능하다.
데이터를 private으로 선언하고 끝냈을 때 의미가 있는 경우도 있지만,
외부에서 접근해서 쓸 수 있어야 하기 때문에 값을 가져가기 위한 getter,
값을 저장 수정하기 위한 setter함수를 public으로 선언해서 사용한다.
클래스 정의 대상:
public, default (class앞에 아무것도 안 붙인것이 default)
인스턴스 변수와 메소드 대상:
public, protected, default, private (4가지 모두)
모든 파일에서 접근 가능, 어디서든 인스턴스 생성이 가능하다.
public클래스는 외부에 노출시키기 위한 클래스이다.
= 열어보지 않아도 파일 이름만으로 내용을 유추할 수 있어야한다.
= 하나의 소스코드에는 하나의 public 클래스만 만들 수 있다.
= public 클래스의 이름은 .java의 이름과 동일해야한다.
public class AAA{ //파일의 이름은 public클래스이기 때문에 AAA.java여야만 함
...
}
패키지로 묶인 클래스 내에서만(같은 패키지 내에서만) 인스턴스 생성을 허용한다.
이름 앞에 접근 제한자를 붙이지 않으면 defalut이다.
(= 아무 선언도 하지 않은 것, **default는 키워드가 아니다.**)
class ZZZ{ //.java 파일이름을 ZZZ외에 다른것으로 정하는 것도 가능함
...
}
주의 Main 에서 다 처리 하지 말고, 객체 지향적(클래스로 만들어서)으로 짜시오.
===================================================================
가위, 바위, 보 중 하나를 입력하세요.
가위
바위
졌습니다.
계속하시겠습니까?(Y/N)
y
가위, 바위, 보 중 하나를 입력하세요.
바위
바위
비겼습니다.
계속하시겠습니까?(Y/N)
n
프로그램을 종료합니다.
public class RockScissorsPaper {
private int com;
private String me;
public RockScissorsPaper(String myAnswer) {
this.me = myAnswer;
}
public void getResult() {
com = (int) (Math.random() * 3 + 1);
if (com == 1) {
System.out.println("가위");
}
else if (com == 2) {
System.out.println("바위");
}
else {
System.out.println("보");
}
if ((me.equals("가위")) && (com == 1)) {
System.out.println("비겼습니다.");
} else if ((me.equals("가위")) && (com == 2)) {
System.out.println("졌습니다.");
} else if ((me.equals("가위")) && (com == 3)) {
System.out.println("이겼습니다.");
} else if ((me.equals("바위")) && (com == 1)) {
System.out.println("이겼습니다.");
} else if ((me.equals("바위")) && (com == 2)) {
System.out.println("비겼습니다.");
} else if ((me.equals("바위")) && (com == 3)) {
System.out.println("졌습니다.");
} else if ((me.equals("보")) && (com == 1)) {
System.out.println("졌습니다.");
} else if ((me.equals("보")) && (com == 2)) {
System.out.println("이겼습니다.");
} else {
System.out.println("비겼습니다.");
}
}
}
package test_package;
import java.util.Scanner;
public class RspTest{
public static void main(String[] args) {
while (true) {
System.out.println("가위, 바위, 보 중 하나를 입력하세요.");
Scanner scanner = new Scanner(System.in);
String myAnswer = scanner.next();
RockScissorsPaper game = new RockScissorsPaper(myAnswer);
game.getResult();
System.out.println("계속하시겠습니까?(Y/N)");
char yesOrNo = scanner.next().charAt(0);
if (yesOrNo == 'y' || yesOrNo == 'Y') {
continue;
} else
break;
}
System.out.println("프로그램을 종료합니다.");
}
}
너무 어려워요 강사님꺼 훔쳐서 보는데 걍.. 와카라나이요...