자바-퀵 가이드

Java 프로그래밍 언어는 원래 James Gosling이 시작하여 1995 년 Sun Microsystems의 Java 플랫폼 (Java 1.0 [J2SE])의 핵심 구성 요소로 출시 된 Sun Microsystems에서 개발했습니다.

Java Standard Edition의 최신 릴리스는 Java SE 8입니다. Java의 발전과 널리 보급됨에 따라 다양한 유형의 플랫폼에 맞게 여러 구성이 구축되었습니다. 예 : 엔터프라이즈 애플리케이션 용 J2EE, 모바일 애플리케이션 용 J2ME.

새로운 J2 버전은 각각 Java SE, Java EE 및 Java ME로 이름이 변경되었습니다. Java는Write Once, Run Anywhere.

자바는-

  • Object Oriented− Java에서는 모든 것이 객체입니다. Java는 Object 모델을 기반으로하기 때문에 쉽게 확장 할 수 있습니다.

  • Platform Independent− C 및 C ++를 포함한 다른 많은 프로그래밍 언어와 달리 Java가 컴파일 될 때 플랫폼에 독립적 인 바이트 코드로 컴파일되는 것이 아니라 플랫폼 별 머신으로 컴파일됩니다. 이 바이트 코드는 웹을 통해 배포되며 실행되는 플랫폼의 가상 머신 (JVM)에 의해 해석됩니다.

  • Simple− Java는 배우기 쉽도록 설계되었습니다. OOP Java의 기본 개념을 이해하면 마스터하기 쉽습니다.

  • Secure− Java의 보안 기능을 통해 바이러스가없고 변조가없는 시스템을 개발할 수 있습니다. 인증 기술은 공개 키 암호화를 기반으로합니다.

  • Architecture-neutral − Java 컴파일러는 아키텍처 중립적 객체 파일 형식을 생성하여 컴파일 된 코드를 Java 런타임 시스템이있는 여러 프로세서에서 실행 가능하게합니다.

  • Portable− 아키텍처 중립적이며 사양의 구현에 따른 측면이 없기 때문에 Java를 이식 할 수 있습니다. Java의 컴파일러는 POSIX 하위 집합 인 명확한 이식성 경계를 사용하여 ANSI C로 작성되었습니다.

  • Robust − Java는 주로 컴파일 시간 오류 검사 및 런타임 검사를 강조하여 오류가 발생하기 쉬운 상황을 제거하기 위해 노력합니다.

  • Multithreaded− Java의 멀티 스레드 기능을 사용하면 여러 작업을 동시에 수행 할 수있는 프로그램을 작성할 수 있습니다. 이 디자인 기능을 통해 개발자는 원활하게 실행할 수있는 대화 형 응용 프로그램을 구성 할 수 있습니다.

  • Interpreted− Java 바이트 코드는 즉석에서 원시 기계 명령어로 변환되며 어디에도 저장되지 않습니다. 연결이 점진적이고 가벼운 프로세스이기 때문에 개발 프로세스가 더 빠르고 분석적입니다.

  • High Performance − Just-In-Time 컴파일러를 사용하여 Java는 고성능을 지원합니다.

  • Distributed − Java는 인터넷의 분산 환경을 위해 설계되었습니다.

  • Dynamic− Java는 진화하는 환경에 적응하도록 설계되었으므로 C 또는 C ++보다 더 동적 인 것으로 간주됩니다. Java 프로그램은 런타임에 개체에 대한 액세스를 확인하고 해결하는 데 사용할 수있는 광범위한 런타임 정보를 전달할 수 있습니다.

자바의 역사

James Gosling은 1991 년 6 월 자신의 여러 셋톱 박스 프로젝트 중 하나에 사용하기 위해 Java 언어 프로젝트를 시작했습니다. Gosling의 사무실 밖에 서 있던 오크 나무의 이름을 따서 처음에 'Oak'이라고 불렸던이 언어는 'Green'이라는 이름으로 바뀌었고 나중에 무작위 단어 목록에서 Java로 이름이 바뀌 었습니다.

Sun은 1995 년에 Java 1.0으로 최초의 공개 구현을 발표했습니다. Write Once, Run Anywhere (WORA), 인기있는 플랫폼에서 무료 런타임을 제공합니다.

2006 년 11 월 13 일 Sun은 GNU GPL (General Public License) 조건에 따라 대부분의 Java를 무료 및 오픈 소스 소프트웨어로 출시했습니다.

2007 년 5 월 8 일 썬은 썬이 저작권을 보유하지 않은 코드의 일부를 제외하고 자바의 모든 핵심 코드를 무료 및 오픈 소스로 만드는 과정을 마쳤습니다.

필요한 도구

이 자습서에서 설명하는 예제를 수행하려면 최소 64MB RAM (128MB RAM 권장)이있는 Pentium 200MHz 컴퓨터가 필요합니다.

또한 다음 소프트웨어가 필요합니다.

  • Linux 7.1 또는 Windows xp / 7 / 8 운영 체제
  • 자바 JDK 8
  • Microsoft 메모장 또는 기타 텍스트 편집기

이 자습서는 Java를 사용하여 GUI, 네트워킹 및 웹 응용 프로그램을 만드는 데 필요한 기술을 제공합니다.

다음은 무엇입니까?

다음 장에서는 Java 및 설명서를 얻는 방법을 안내합니다. 마지막으로 Java를 설치하고 Java 애플리케이션을 개발하기위한 환경을 준비하는 방법에 대해 설명합니다.

이 장에서는 Java에 적합한 환경을 설정하는 다양한 측면에 대해 설명합니다.

지역 환경 설정

여전히 Java 프로그래밍 언어에 대한 환경을 설정하려는 경우이 섹션에서는 시스템에서 Java를 다운로드하고 설정하는 방법을 안내합니다. 다음은 환경을 설정하는 단계입니다.

Java SE는 Java 다운로드 링크에서 무료로 사용할 수 있습니다 . 운영 체제에 따라 버전을 다운로드 할 수 있습니다.

지침에 따라 Java를 다운로드하고 .exe컴퓨터에 Java를 설치합니다. 시스템에 Java를 설치 한 후에는 올바른 설치 디렉토리를 가리 키도록 환경 변수를 설정해야합니다.

Windows 용 경로 설정

c : \ Program Files \ java \ jdk 디렉토리에 Java를 설치했다고 가정합니다 .

  • '내 컴퓨터'를 마우스 오른쪽 버튼으로 클릭하고 '속성'을 선택합니다.

  • '고급'탭에서 '환경 변수'버튼을 클릭합니다.

  • 이제 Java 실행 파일의 경로도 포함하도록 'Path'변수를 변경하십시오. 예를 들어 현재 경로가 'C : \ WINDOWS \ SYSTEM32'로 설정된 경우 경로를 'C : \ WINDOWS \ SYSTEM32; c : \ Program Files \ java \ jdk \ bin'으로 변경합니다.

Linux, UNIX, Solaris, FreeBSD에 대한 경로 설정

환경 변수 PATH는 Java 바이너리가 설치된 위치를 가리 키도록 설정되어야합니다. 이 작업을 수행하는 데 문제가 있으면 쉘 문서를 참조하십시오.

예를 들어 bash 를 셸로 사용하는 경우 '.bashrc : export PATH = / path / to / java : $ PATH'끝에 다음 줄을 추가합니다.

인기있는 자바 편집자

Java 프로그램을 작성하려면 텍스트 편집기가 필요합니다. 시장에는 훨씬 더 정교한 IDE가 있습니다. 그러나 지금은 다음 중 하나를 고려할 수 있습니다.

  • Notepad − Windows 컴퓨터에서는 메모장 (이 자습서에 권장 됨), TextPad와 같은 간단한 텍스트 편집기를 사용할 수 있습니다.

  • Netbeans − 오픈 소스이며 무료로 제공되는 Java IDE https://www.netbeans.org/index.html.

  • Eclipse − Eclipse 오픈 소스 커뮤니티에서 개발 한 Java IDE이며 다음에서 다운로드 할 수 있습니다. https://www.eclipse.org/.

다음은 무엇입니까?

다음 장에서는 첫 번째 Java 프로그램을 작성하고 실행하는 방법과 애플리케이션 개발에 필요한 Java의 몇 가지 중요한 기본 구문을 설명합니다.

Java 프로그램을 고려할 때 서로의 메소드를 호출하여 통신하는 객체의 모음으로 정의 할 수 있습니다. 이제 클래스, 객체, 메서드 및 인스턴스 변수가 무엇을 의미하는지 간략하게 살펴 보겠습니다.

  • Object− 개체에는 상태와 동작이 있습니다. 예 : 개는 색깔, 이름, 품종뿐만 아니라 꼬리 흔들기, 짖기, 먹기 등의 상태를 가지고 있습니다. 객체는 클래스의 인스턴스입니다.

  • Class − 클래스는 해당 유형의 객체가 지원하는 동작 / 상태를 설명하는 템플릿 / 청사진으로 정의 할 수 있습니다.

  • Methods− 방법은 기본적으로 행동입니다. 클래스에는 여러 메서드가 포함될 수 있습니다. 논리가 작성되고 데이터가 조작되고 모든 작업이 실행되는 메서드에 있습니다.

  • Instance Variables− 각 개체에는 고유 한 인스턴스 변수 세트가 있습니다. 개체의 상태는 이러한 인스턴스 변수에 할당 된 값에 의해 생성됩니다.

첫 번째 자바 프로그램

단어를 인쇄 할 간단한 코드를 살펴 보겠습니다. Hello World.

public class MyFirstJavaProgram {

   /* This is my first java program.
    * This will print 'Hello World' as the output
    */

   public static void main(String []args) {
      System.out.println("Hello World"); // prints Hello World
   }
}

파일 저장, 컴파일 및 프로그램 실행 방법을 살펴 보겠습니다. 다음 단계를 따르십시오-

  • 메모장을 열고 위와 같이 코드를 추가합니다.

  • 파일을 MyFirstJavaProgram.java로 저장하십시오.

  • 명령 프롬프트 창을 열고 클래스를 저장 한 디렉토리로 이동합니다. C : \라고 가정합니다.

  • 'javac MyFirstJavaProgram.java'를 입력하고 Enter 키를 눌러 코드를 컴파일합니다. 코드에 오류가 없으면 명령 프롬프트가 다음 줄로 이동합니다 (가정 : 경로 변수가 설정 됨).

  • 이제 'java MyFirstJavaProgram'을 입력하여 프로그램을 실행하십시오.

  • 창에 'Hello World'가 인쇄 된 것을 볼 수 있습니다.

산출

C:\> javac MyFirstJavaProgram.java
C:\> java MyFirstJavaProgram 
Hello World

기본 구문

Java 프로그램에 대해 다음 사항을 염두에 두는 것이 매우 중요합니다.

  • Case Sensitivity − Java는 대소 문자를 구분하므로 식별자를 의미합니다. Hellohello Java에서는 다른 의미를 갖습니다.

  • Class Names− 모든 클래스 이름에 대해 첫 글자는 대문자 여야합니다. 여러 단어를 사용하여 클래스 이름을 구성하는 경우 각 내부 단어의 첫 글자는 대문자 여야합니다.

    Example: MyFirstJavaClass 클래스

  • Method Names− 모든 메소드 이름은 소문자로 시작해야합니다. 메서드 이름을 구성하기 위해 여러 단어를 사용하는 경우 각 내부 단어의 첫 글자는 대문자 여야합니다.

    Example: public void myMethodName ()

  • Program File Name − 프로그램 파일의 이름은 클래스 이름과 정확히 일치해야합니다.

    파일을 저장할 때 클래스 이름 (Java는 대소 문자 구분)을 사용하여 저장하고 이름 끝에 '.java'를 추가해야합니다 (파일 이름과 클래스 이름이 일치하지 않으면 프로그램이 컴파일되지 않습니다). ).

    Example:'MyFirstJavaProgram'이 클래스 이름이라고 가정합니다. 그런 다음 파일은 'MyFirstJavaProgram.java' 로 저장되어야합니다.

  • public static void main(String args[]) − Java 프로그램 처리는 모든 Java 프로그램의 필수 부분 인 main () 메소드에서 시작됩니다.

자바 식별자

모든 Java 구성 요소에는 이름이 필요합니다. 클래스, 변수 및 메서드에 사용되는 이름이 호출됩니다.identifiers.

Java에는 식별자에 대해 기억해야 할 몇 가지 사항이 있습니다. 그들은 다음과 같습니다-

  • 모든 식별자는 문자 (A-Z 또는 a-z), 통화 문자 ($) 또는 밑줄 (_)로 시작해야합니다.

  • 첫 번째 문자 뒤에 식별자는 모든 문자 조합을 가질 수 있습니다.

  • 키워드는 식별자로 사용할 수 없습니다.

  • 가장 중요한 것은 식별자가 대소 문자를 구분한다는 것입니다.

  • 유효한 식별자의 예 : age, $ salary, _value, __1_value.

  • 잘못된 식별자의 예 : 123abc, -salary.

자바 수정 자

다른 언어와 마찬가지로 수정자를 사용하여 클래스, 메서드 등을 수정할 수 있습니다. 수정 자에는 두 가지 범주가 있습니다.

  • Access Modifiers − 기본, 공개, 보호, 비공개

  • Non-access Modifiers − 최종, 추상, strictfp

다음 섹션에서 수정 자에 대한 자세한 내용을 살펴 보겠습니다.

자바 변수

다음은 Java의 변수 유형입니다-

  • 지역 변수
  • 클래스 변수 (정적 변수)
  • 인스턴스 변수 (비 정적 변수)

자바 어레이

배열은 동일한 유형의 여러 변수를 저장하는 객체입니다. 그러나 배열 자체는 힙의 개체입니다. 다음 장에서 선언, 구성 및 초기화하는 방법을 살펴볼 것입니다.

자바 열거 형

열거 형은 Java 5.0에서 도입되었습니다. 열거 형은 미리 정의 된 몇 가지 값 중 하나만 갖도록 변수를 제한합니다. 이 열거 형 목록의 값을 열거 형이라고합니다.

열거 형을 사용하면 코드의 버그 수를 줄일 수 있습니다.

예를 들어, 신선한 주스 가게에 대한 응용 프로그램을 고려하면 유리 크기를 소형, 중형 및 대형으로 제한 할 수 있습니다. 이렇게하면 누구도 소형, 중형 또는 대형 이외의 크기를 주문할 수 없습니다.

class FreshJuice {
   enum FreshJuiceSize{ SMALL, MEDIUM, LARGE }
   FreshJuiceSize size;
}

public class FreshJuiceTest {

   public static void main(String args[]) {
      FreshJuice juice = new FreshJuice();
      juice.size = FreshJuice.FreshJuiceSize.MEDIUM ;
      System.out.println("Size: " + juice.size);
   }
}

위의 예는 다음 결과를 생성합니다.

산출

Size: MEDIUM

Note− 열거 형은 자체 또는 클래스 내부로 선언 할 수 있습니다. 메서드, 변수, 생성자도 열거 형 안에 정의 할 수 있습니다.

자바 키워드

다음 목록은 Java의 예약어를 보여줍니다. 이러한 예약어는 상수, 변수 또는 기타 식별자 이름으로 사용할 수 없습니다.

요약 주장하다 부울 단절
바이트 케이스 잡기
수업 const 계속하다 기본
하다 더블 그밖에 열거 형
연장하다 결정적인 드디어 흙손
...에 대한 이동 만약 구현
수입 대신에 int 상호 작용
원주민 새로운 꾸러미
은밀한 보호 공공의 반환
짧은 공전 strictfp 감독자
스위치 동기화 됨 던지다
던지다 과도 현상 시험
휘발성 물질 동안

자바 주석

Java는 C 및 C ++와 매우 유사한 한 줄 및 여러 줄 주석을 지원합니다. 주석 내에서 사용할 수있는 모든 문자는 Java 컴파일러에서 무시됩니다.

public class MyFirstJavaProgram {

   /* This is my first java program.
    * This will print 'Hello World' as the output
    * This is an example of multi-line comments.
    */

   public static void main(String []args) {
      // This is an example of single line comment
      /* This is also an example of single line comment. */
      System.out.println("Hello World");
   }
}

산출

Hello World

빈 줄 사용

주석이있는 공백 만 포함 된 행을 공백 행이라고하며 Java는이를 완전히 무시합니다.

계승

Java에서 클래스는 클래스에서 파생 될 수 있습니다. 기본적으로 새 클래스를 만들어야하고 여기에 필요한 코드가 이미있는 클래스가있는 경우 이미 존재하는 코드에서 새 클래스를 파생 할 수 있습니다.

이 개념을 사용하면 새 클래스에서 코드를 다시 작성할 필요없이 기존 클래스의 필드와 메서드를 다시 사용할 수 있습니다. 이 시나리오에서 기존 클래스는superclass 파생 클래스는 subclass.

인터페이스

Java 언어에서 인터페이스는 서로 통신하는 방법에 대한 개체 간의 계약으로 정의 할 수 있습니다. 인터페이스는 상속 개념과 관련하여 중요한 역할을합니다.

인터페이스는 메서드를 정의하며 파생 클래스 (서브 클래스)가 사용해야합니다. 그러나 메소드의 구현은 전적으로 하위 클래스에 달려 있습니다.

다음은 무엇입니까?

다음 섹션에서는 Java 프로그래밍의 객체 및 클래스에 대해 설명합니다. 세션이 끝나면 객체가 무엇이고 Java의 클래스가 무엇인지에 대한 명확한 그림을 얻을 수 있습니다.

Java는 객체 지향 언어입니다. 객체 지향 기능을 가진 언어로서 Java는 다음과 같은 기본 개념을 지원합니다.

  • Polymorphism
  • Inheritance
  • Encapsulation
  • Abstraction
  • Classes
  • Objects
  • Instance
  • Method
  • 메시지 전달

이 장에서는 개념-클래스 및 객체를 살펴볼 것입니다.

  • Object− 개체에는 상태와 동작이 있습니다. 예 : 개는 꼬리를 흔드는 것, 짖는 것, 먹는 것 등의 상태 (색, 이름, 품종 및 행동)를 가지고 있습니다. 객체는 클래스의 인스턴스입니다.

  • Class − 클래스는 해당 유형의 객체가 지원하는 동작 / 상태를 설명하는 템플릿 / 청사진으로 정의 할 수 있습니다.

자바의 객체

이제 객체가 무엇인지 자세히 살펴 보겠습니다. 현실 세계를 고려하면 우리 주변의 많은 물체, 자동차, 개, 인간 등을 찾을 수 있습니다.이 모든 물체에는 상태와 행동이 있습니다.

개를 고려하면 그 상태는 이름, 번식, 색이며 행동은-짖고, 꼬리를 흔들고, 달리는 것입니다.

소프트웨어 개체를 실제 개체와 비교하면 매우 유사한 특성이 있습니다.

소프트웨어 개체에는 상태와 동작도 있습니다. 소프트웨어 개체의 상태는 필드에 저장되고 동작은 메서드를 통해 표시됩니다.

따라서 소프트웨어 개발에서 메서드는 개체의 내부 상태에서 작동하고 개체 간 통신은 메서드를 통해 수행됩니다.

자바 클래스

클래스는 개별 객체가 생성되는 청사진입니다.

다음은 수업 샘플입니다.

public class Dog {
   String breed;
   int age;
   String color;

   void barking() {
   }

   void hungry() {
   }

   void sleeping() {
   }
}

클래스는 다음 변수 유형을 포함 할 수 있습니다.

  • Local variables− 메서드, 생성자 또는 블록 내에 정의 된 변수를 지역 변수라고합니다. 변수는 메서드 내에서 선언되고 초기화되며 메서드가 완료되면 변수가 소멸됩니다.

  • Instance variables− 인스턴스 변수는 클래스 내부에 있지만 메서드 외부에있는 변수입니다. 이러한 변수는 클래스가 인스턴스화 될 때 초기화됩니다. 인스턴스 변수는 특정 클래스의 모든 메서드, 생성자 또는 블록 내에서 액세스 할 수 있습니다.

  • Class variables − 클래스 변수는 static 키워드를 사용하여 메서드 외부의 클래스 내에서 선언 된 변수입니다.

클래스는 다양한 종류의 메서드 값에 액세스하기 위해 여러 메서드를 가질 수 있습니다. 위의 예에서 barking (), hungry () 및 sleeping ()은 메소드입니다.

다음은 Java 언어 클래스를 살펴볼 때 논의해야하는 몇 가지 중요한 주제입니다.

생성자

클래스에 대해 논의 할 때 가장 중요한 하위 주제 중 하나는 생성자입니다. 모든 클래스에는 생성자가 있습니다. 클래스에 대한 생성자를 명시 적으로 작성하지 않으면 Java 컴파일러는 해당 클래스에 대한 기본 생성자를 빌드합니다.

새 객체가 생성 될 때마다 하나 이상의 생성자가 호출됩니다. 생성자의 주요 규칙은 클래스와 동일한 이름을 가져야한다는 것입니다. 클래스에는 둘 이상의 생성자가있을 수 있습니다.

다음은 생성자의 예입니다.

public class Puppy {
   public Puppy() {
   }

   public Puppy(String name) {
      // This constructor has one parameter, name.
   }
}

Java는 클래스의 인스턴스를 하나만 만들 수있는 싱글 톤 클래스 도 지원합니다 .

Note− 두 가지 유형의 생성자가 있습니다. 생성자에 대해서는 다음 장에서 자세히 설명하겠습니다.

개체 만들기

앞서 언급했듯이 클래스는 객체에 대한 청사진을 제공합니다. 따라서 기본적으로 객체는 클래스에서 생성됩니다. Java에서 new 키워드는 새 개체를 만드는 데 사용됩니다.

클래스에서 객체를 만들 때 세 단계가 있습니다-

  • Declaration − 객체 유형이있는 변수 이름이있는 변수 선언.

  • Instantiation − 'new'키워드는 개체를 생성하는 데 사용됩니다.

  • Initialization− 'new'키워드 뒤에 생성자 호출이 이어집니다. 이 호출은 새 개체를 초기화합니다.

다음은 객체 생성의 예입니다-

public class Puppy {
   public Puppy(String name) {
      // This constructor has one parameter, name.
      System.out.println("Passed Name is :" + name );
   }

   public static void main(String []args) {
      // Following statement would create an object myPuppy
      Puppy myPuppy = new Puppy( "tommy" );
   }
}

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

산출

Passed Name is :tommy

인스턴스 변수 및 메서드에 액세스

인스턴스 변수와 메서드는 생성 된 객체를 통해 액세스됩니다. 인스턴스 변수에 액세스하려면 다음은 완전한 경로입니다.

/* First create an object */
ObjectReference = new Constructor();

/* Now call a variable as follows */
ObjectReference.variableName;

/* Now you can call a class method as follows */
ObjectReference.MethodName();

이 예제에서는 클래스의 인스턴스 변수 및 메서드에 액세스하는 방법을 설명합니다.

public class Puppy {
   int puppyAge;

   public Puppy(String name) {
      // This constructor has one parameter, name.
      System.out.println("Name chosen is :" + name );
   }

   public void setAge( int age ) {
      puppyAge = age;
   }

   public int getAge( ) {
      System.out.println("Puppy's age is :" + puppyAge );
      return puppyAge;
   }

   public static void main(String []args) {
      /* Object creation */
      Puppy myPuppy = new Puppy( "tommy" );

      /* Call class method to set puppy's age */
      myPuppy.setAge( 2 );

      /* Call another class method to get puppy's age */
      myPuppy.getAge( );

      /* You can access instance variable as follows as well */
      System.out.println("Variable Value :" + myPuppy.puppyAge );
   }
}

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과가 생성됩니다.

산출

Name chosen is :tommy
Puppy's age is :2
Variable Value :2

소스 파일 선언 규칙

이 섹션의 마지막 부분에서 이제 소스 파일 선언 규칙을 살펴 보겠습니다. 이러한 규칙은 소스 파일에서 클래스, import 문 및 패키지 문을 선언 할 때 필수적 입니다.

  • 소스 파일 당 하나의 공용 클래스 만있을 수 있습니다.

  • 소스 파일에는 여러 개의 비공개 클래스가있을 수 있습니다.

  • 공개 클래스 이름은 소스 파일의 이름이어야하며 다음이 추가되어야합니다. .java끝에. 예 : 클래스 이름이 공용 클래스 Employee {} 이고 소스 파일은 Employee.java 여야합니다.

  • 클래스가 패키지 내부에 정의 된 경우 패키지 문은 소스 파일의 첫 번째 문이어야합니다.

  • import 문이있는 경우 패키지 문과 클래스 선언 사이에 작성해야합니다. 패키지 문이없는 경우 import 문은 소스 파일의 첫 번째 줄에 있어야합니다.

  • 가져 오기 및 패키지 문은 소스 파일에있는 모든 클래스를 의미합니다. 소스 파일의 다른 클래스에 다른 import 및 / 또는 package 문을 선언 할 수 없습니다.

클래스에는 여러 액세스 수준이 있으며 다양한 유형의 클래스가 있습니다. 추상 클래스, 최종 클래스 등. 액세스 수정 자 장에서이 모든 것에 대해 설명 할 것입니다.

위에서 언급 한 클래스 유형 외에도 Java에는 내부 클래스 및 익명 클래스라는 특수 클래스도 있습니다.

자바 패키지

간단히 말해서 클래스와 인터페이스를 분류하는 방법입니다. Java로 애플리케이션을 개발할 때 수백 개의 클래스와 인터페이스가 작성되므로 이러한 클래스를 분류하는 것은 필수 일뿐만 아니라 삶을 훨씬 쉽게 만듭니다.

수입 명세서

Java에서 패키지 및 클래스 이름을 포함하는 완전한 이름이 제공되면 컴파일러는 소스 코드 또는 클래스를 쉽게 찾을 수 있습니다. Import 문은 컴파일러가 특정 클래스를 찾을 수있는 적절한 위치를 제공하는 방법입니다.

예를 들어, 다음 줄은 컴파일러에게 java_installation / java / io 디렉토리에서 사용 가능한 모든 클래스를로드하도록 요청합니다.

import java.io.*;

간단한 사례 연구

사례 연구를 위해 두 개의 클래스를 만들 것입니다. Employee와 EmployeeTest입니다.

먼저 메모장을 열고 다음 코드를 추가하십시오. 이것은 Employee 클래스이고 클래스는 공용 클래스임을 기억하십시오. 이제이 소스 파일을 Employee.java라는 이름으로 저장하십시오.

Employee 클래스에는 이름, 나이, 지정 및 급여의 네 가지 인스턴스 변수가 있습니다. 클래스에는 매개 변수를 사용하는 명시 적으로 정의 된 생성자가 하나 있습니다.

import java.io.*;
public class Employee {

   String name;
   int age;
   String designation;
   double salary;

   // This is the constructor of the class Employee
   public Employee(String name) {
      this.name = name;
   }

   // Assign the age of the Employee  to the variable age.
   public void empAge(int empAge) {
      age = empAge;
   }

   /* Assign the designation to the variable designation.*/
   public void empDesignation(String empDesig) {
      designation = empDesig;
   }

   /* Assign the salary to the variable	salary.*/
   public void empSalary(double empSalary) {
      salary = empSalary;
   }

   /* Print the Employee details */
   public void printEmployee() {
      System.out.println("Name:"+ name );
      System.out.println("Age:" + age );
      System.out.println("Designation:" + designation );
      System.out.println("Salary:" + salary);
   }
}

이 자습서에서 앞서 언급했듯이 처리는 기본 방법에서 시작됩니다. 따라서이 Employee 클래스를 실행하려면 메인 메소드가 있어야하고 객체가 생성되어야합니다. 이러한 작업에 대해 별도의 클래스를 만들 것입니다.

다음은 Employee 클래스의 두 인스턴스를 만들고 각 개체에 대한 메서드를 호출하여 각 변수에 값을 할당하는 EmployeeTest 클래스입니다.

EmployeeTest.java 파일에 다음 코드를 저장합니다.

import java.io.*;
public class EmployeeTest {

   public static void main(String args[]) {
      /* Create two objects using constructor */
      Employee empOne = new Employee("James Smith");
      Employee empTwo = new Employee("Mary Anne");

      // Invoking methods for each object created
      empOne.empAge(26);
      empOne.empDesignation("Senior Software Engineer");
      empOne.empSalary(1000);
      empOne.printEmployee();

      empTwo.empAge(21);
      empTwo.empDesignation("Software Engineer");
      empTwo.empSalary(500);
      empTwo.printEmployee();
   }
}

이제 두 클래스를 모두 컴파일 한 다음 EmployeeTest 를 실행 하여 다음과 같이 결과를 확인합니다.

산출

C:\> javac Employee.java
C:\> javac EmployeeTest.java
C:\> java EmployeeTest
Name:James Smith
Age:26
Designation:Senior Software Engineer
Salary:1000.0
Name:Mary Anne
Age:21
Designation:Software Engineer
Salary:500.0

다음은 무엇입니까?

다음 세션에서는 Java의 기본 데이터 유형과 Java 응용 프로그램을 개발할 때 어떻게 사용할 수 있는지에 대해 설명합니다.

생성자는 생성 될 때 객체를 초기화합니다. 클래스와 이름이 같고 구문 적으로 메서드와 유사합니다. 그러나 생성자에는 명시적인 반환 유형이 없습니다.

일반적으로 생성자를 사용하여 클래스에서 정의한 인스턴스 변수에 초기 값을 제공하거나 완전한 형식의 개체를 만드는 데 필요한 다른 시작 절차를 수행합니다.

Java는 모든 멤버 변수를 0으로 초기화하는 기본 생성자를 자동으로 제공하기 때문에 모든 클래스에는 생성자가 있습니다. 그러나 자신의 생성자를 정의하면 기본 생성자가 더 이상 사용되지 않습니다.

통사론

다음은 생성자의 구문입니다-

class ClassName {
   ClassName() {
   }
}

Java는 두 가지 유형의 생성자를 허용합니다.

  • 인수 생성자 없음
  • 매개 변수화 된 생성자

인수 생성자 없음

이름이 지정하는대로 Java의 인수 없음 생성자는 매개 변수를 대신 받아들이지 않으므로 이러한 생성자를 사용하면 메서드의 인스턴스 변수가 모든 객체에 대한 고정 값으로 초기화됩니다.

Public class MyClass {
   Int num;
   MyClass() {
      num = 100;
   }
}

생성자를 호출하여 다음과 같이 객체를 초기화합니다.

public class ConsDemo {
   public static void main(String args[]) {
      MyClass t1 = new MyClass();
      MyClass t2 = new MyClass();
      System.out.println(t1.num + " " + t2.num);
   }
}

이것은 다음 결과를 생성합니다

100 100

매개 변수화 된 생성자

대부분의 경우 하나 이상의 매개 변수를 허용하는 생성자가 필요합니다. 매개 변수는 메소드에 추가되는 것과 동일한 방식으로 생성자에 추가됩니다. 생성자 이름 뒤의 괄호 안에 선언하기 만하면됩니다.

다음은 생성자를 사용하는 간단한 예입니다.

// A simple constructor.
class MyClass {
   int x;
   
   // Following is the constructor
   MyClass(int i ) {
      x = i;
   }
}

생성자를 호출하여 다음과 같이 객체를 초기화합니다.

public class ConsDemo {
   public static void main(String args[]) {
      MyClass t1 = new MyClass( 10 );
      MyClass t2 = new MyClass( 20 );
      System.out.println(t1.x + " " + t2.x);
   }
}

이것은 다음 결과를 생성합니다-

10 20

변수는 값을 저장하기 위해 예약 된 메모리 위치 일뿐입니다. 이것은 변수를 만들 때 메모리에 약간의 공간을 예약한다는 것을 의미합니다.

변수의 데이터 유형에 따라 운영 체제는 메모리를 할당하고 예약 된 메모리에 저장할 수있는 항목을 결정합니다. 따라서 변수에 서로 다른 데이터 유형을 할당하여 이러한 변수에 정수, 소수 또는 문자를 저장할 수 있습니다.

자바에서 사용할 수있는 두 가지 데이터 유형이 있습니다-

  • 원시 데이터 유형
  • 참조 / 객체 데이터 유형

원시 데이터 유형

Java에서 지원하는 8 개의 기본 데이터 유형이 있습니다. 원시 데이터 유형은 언어로 사전 정의되고 키워드로 이름이 지정됩니다. 이제 8 가지 기본 데이터 유형을 자세히 살펴 보겠습니다.

바이트

  • 바이트 데이터 유형은 8 비트 부호있는 2의 보수 정수입니다.

  • 최소값은 -128 (-2 ^ 7)입니다.

  • 최대 값은 127 (포함) (2 ^ 7 -1)입니다.

  • 기본값은 0입니다.

  • 바이트 데이터 유형은 바이트가 정수보다 4 배 작기 때문에 주로 정수 대신 큰 배열에서 공간을 절약하는 데 사용됩니다.

  • 예 : byte a = 100, byte b = -50

짧은

  • Short 데이터 유형은 16 비트 부호있는 2의 보수 정수입니다.

  • 최소값은 -32,768 (-2 ^ 15)입니다.

  • 최대 값은 32,767 (포함) (2 ^ 15 -1)입니다.

  • Short 데이터 유형은 또한 메모리를 바이트 데이터 유형으로 저장하는 데 사용할 수 있습니다. short는 정수보다 2 배 작습니다.

  • 기본값은 0입니다.

  • 예 : short s = 10000, short r = -20000

int

  • Int 데이터 유형은 32 비트 부호있는 2의 보수 정수입니다.

  • 최소값은-2,147,483,648 (-2 ^ 31)입니다.

  • 최대 값은 2,147,483,647 (포함) (2 ^ 31 -1)입니다.

  • 메모리에 대한 우려가없는 한 정수는 일반적으로 정수 값의 기본 데이터 유형으로 사용됩니다.

  • 기본값은 0입니다.

  • 예 : int a = 100000, int b = -200000

  • Long 데이터 유형은 64 비트 부호있는 2의 보수 정수입니다.
  • 최소값은 -9,223,372,036,854,775,808 (-2 ^ 63)입니다.
  • 최대 값은 9,223,372,036,854,775,807 (포함) (2 ^ 63 -1)입니다.
  • 이 유형은 int보다 더 넓은 범위가 필요할 때 사용됩니다.
  • 기본값은 0L입니다.
  • 예 : long a = 100000L, long b = -200000L

흙손

  • 부동 데이터 유형은 단 정밀도 32 비트 IEEE 754 부동 소수점입니다.

  • Float는 주로 부동 소수점 숫자의 큰 배열에서 메모리를 절약하는 데 사용됩니다.

  • 기본값은 0.0f입니다.

  • 통화와 같은 정확한 값에는 부동 데이터 유형이 사용되지 않습니다.

  • 예 : float f1 = 234.5f

더블

  • double 데이터 유형은 배정 밀도 64 비트 IEEE 754 부동 소수점입니다.

  • 이 데이터 유형은 일반적으로 10 진수 값의 기본 데이터 유형으로 사용되며 일반적으로 기본 선택입니다.

  • 통화와 같은 정확한 값에는 Double 데이터 유형을 사용해서는 안됩니다.

  • 기본값은 0.0d입니다.

  • 예 : double d1 = 123.4

부울

  • 부울 데이터 유형은 1 비트 정보를 나타냅니다.
  • 가능한 값은 true와 false입니다.
  • 이 데이터 유형은 참 / 거짓 조건을 추적하는 간단한 플래그에 사용됩니다.
  • 기본값은 거짓입니다.
  • 예 : 부울 1 = true

  • char 데이터 유형은 단일 16 비트 유니 코드 문자입니다.
  • 최소값은 '\ u0000'(또는 0)입니다.
  • 최대 값은 '\ uffff'(또는 65,535 포함)입니다.
  • Char 데이터 유형은 모든 문자를 저장하는 데 사용됩니다.
  • 예 : char letterA = 'A'

참조 데이터 유형

  • 참조 변수는 클래스의 정의 된 생성자를 사용하여 생성됩니다. 개체에 액세스하는 데 사용됩니다. 이러한 변수는 변경할 수없는 특정 유형으로 선언됩니다. 예 : 직원, 강아지 등

  • 클래스 객체와 다양한 유형의 배열 변수는 참조 데이터 유형에 속합니다.

  • 참조 변수의 기본값은 null입니다.

  • 참조 변수는 선언 된 유형 또는 호환 가능한 유형의 모든 개체를 참조하는 데 사용할 수 있습니다.

  • 예 : Animal animal = new Animal ( "giraffe");

자바 리터럴

리터럴은 고정 값의 소스 코드 표현입니다. 계산없이 코드에 직접 표시됩니다.

리터럴은 모든 기본 유형 변수에 할당 될 수 있습니다. 예를 들면-

byte a = 68;
char a = 'A';

byte, int, long, short는 10 진수 (10 진수), 16 진수 (16 진수) 또는 8 진수 (8 진수) 숫자 체계로도 표현할 수 있습니다.

접두사 0은 8 진수를 나타내는 데 사용되며 접두사 0x는 이러한 숫자 체계를 리터럴에 사용할 때 16 진수를 나타냅니다. 예를 들면-

int decimal = 100;
int octal = 0144;
int hexa =  0x64;

Java의 문자열 리터럴은 대부분의 다른 언어에서와 같이 큰 따옴표 쌍 사이에 일련의 문자를 묶어 지정됩니다. 문자열 리터럴의 예는 다음과 같습니다.

"Hello World"
"two\nlines"
"\"This is in quotes\""

문자열 및 문자 유형의 리터럴은 모든 유니 코드 문자를 포함 할 수 있습니다. 예를 들면-

char a = '\u0001';
String a = "\u0001";

Java 언어는 String 및 char 리터럴에 대한 몇 가지 특수 이스케이프 시퀀스도 지원합니다. 그들은-

표기법 대표되는 문자
\엔 줄 바꿈 (0x0a)
\아르 자형 캐리지 리턴 (0x0d)
\에프 폼 피드 (0x0c)
\비 백 스페이스 (0x08)
\에스 공간 (0x20)
\티
\ " 큰 따옴표
\ ' 작은 따옴표
\\ 백 슬래시
\ ddd 8 진 문자 (ddd)
\ uxxxx 16 진수 유니 코드 문자 (xxxx)

다음은 무엇입니까?

이 장에서는 다양한 데이터 유형에 대해 설명했습니다. 다음 항목에서는 다양한 변수 유형과 그 사용법에 대해 설명합니다. 이를 통해 Java 클래스, 인터페이스 등에서 사용할 수있는 방법을 잘 이해할 수 있습니다.

변수는 프로그램이 조작 할 수있는 명명 된 저장소를 제공합니다. Java의 각 변수에는 변수 메모리의 크기와 레이아웃을 결정하는 특정 유형이 있습니다. 해당 메모리 내에 저장할 수있는 값의 범위 변수에 적용 할 수있는 연산 집합입니다.

모든 변수를 사용하려면 먼저 선언해야합니다. 다음은 변수 선언의 기본 형식입니다.

data type variable [ = value][, variable [ = value] ...] ;

여기서 데이터 유형 은 Java의 데이터 유형 중 하나이고 변수변수 의 이름입니다. 지정된 유형의 변수를 두 개 이상 선언하려면 쉼표로 구분 된 목록을 사용할 수 있습니다.

다음은 Java에서 변수 선언 및 초기화의 유효한 예입니다.

int a, b, c;         // Declares three ints, a, b, and c.
int a = 10, b = 10;  // Example of initialization
byte B = 22;         // initializes a byte type variable B.
double pi = 3.14159; // declares and assigns a value of PI.
char a = 'A';        // the char variable a iis initialized with value 'a'

이 장에서는 Java 언어에서 사용할 수있는 다양한 변수 유형에 대해 설명합니다. 자바에는 세 종류의 변수가 있습니다.

  • 지역 변수
  • 인스턴스 변수
  • 클래스 / 정적 변수

지역 변수

  • 지역 변수는 메서드, 생성자 또는 블록에서 선언됩니다.

  • 지역 변수는 메서드, 생성자 또는 블록이 입력 될 때 생성되고 변수가 메서드, 생성자 또는 블록을 종료하면 삭제됩니다.

  • 로컬 변수에는 액세스 수정자를 사용할 수 없습니다.

  • 지역 변수는 선언 된 메서드, 생성자 또는 블록 내에서만 볼 수 있습니다.

  • 지역 변수는 내부적으로 스택 수준에서 구현됩니다.

  • 지역 변수는 기본값이 없으므로 처음 사용하기 전에 지역 변수를 선언하고 초기 값을 할당해야합니다.

여기서 나이 는 지역 변수입니다. 이것은 pupAge () 메서드 내에서 정의 되며 그 범위는이 메서드로만 제한됩니다.

public class Test {
   public void pupAge() {
      int age = 0;
      age = age + 7;
      System.out.println("Puppy age is : " + age);
   }

   public static void main(String args[]) {
      Test test = new Test();
      test.pupAge();
   }
}

이것은 다음 결과를 생성합니다-

산출

Puppy age is: 7

다음 예제는 초기화하지 않고 age 를 사용 하므로 컴파일시 오류가 발생합니다.

public class Test {
   public void pupAge() {
      int age;
      age = age + 7;
      System.out.println("Puppy age is : " + age);
   }

   public static void main(String args[]) {
      Test test = new Test();
      test.pupAge();
   }
}

컴파일하는 동안 다음과 같은 오류가 발생합니다.

산출

Test.java:4:variable number might not have been initialized
age = age + 7;
         ^
1 error

인스턴스 변수

  • 인스턴스 변수는 클래스에서 선언되지만 메서드, 생성자 또는 모든 블록 외부에 있습니다.

  • 힙의 객체에 공간이 할당되면 각 인스턴스 변수 값에 대한 슬롯이 생성됩니다.

  • 인스턴스 변수는 'new'키워드를 사용하여 개체를 만들 때 생성되고 개체가 소멸되면 소멸됩니다.

  • 인스턴스 변수는 둘 이상의 메서드, 생성자 또는 블록 또는 클래스 전체에 존재해야하는 개체 상태의 필수 부분에서 참조해야하는 값을 포함합니다.

  • 인스턴스 변수는 사용 전후에 클래스 수준에서 선언 할 수 있습니다.

  • 인스턴스 변수에 대한 액세스 수정자를 지정할 수 있습니다.

  • 인스턴스 변수는 클래스의 모든 메서드, 생성자 및 블록에 대해 표시됩니다. 일반적으로 이러한 변수를 비공개 (액세스 수준)로 설정하는 것이 좋습니다. 그러나 액세스 수정자를 사용하여 이러한 변수에 대해 하위 클래스에 대한 가시성을 제공 할 수 있습니다.

  • 인스턴스 변수에는 기본값이 있습니다. 숫자의 경우 기본값은 0, 부울의 경우 false, 객체 참조의 경우 null입니다. 선언 중 또는 생성자 내에서 값을 할당 할 수 있습니다.

  • 인스턴스 변수는 클래스 내에서 변수 이름을 호출하여 직접 액세스 할 수 있습니다. 그러나 정적 메서드 내에서 (인스턴스 변수에 접근성이 부여 된 경우) 정규화 된 이름을 사용하여 호출해야합니다. ObjectReference.VariableName .

import java.io.*;
public class Employee {

   // this instance variable is visible for any child class.
   public String name;

   // salary  variable is visible in Employee class only.
   private double salary;

   // The name variable is assigned in the constructor.
   public Employee (String empName) {
      name = empName;
   }

   // The salary variable is assigned a value.
   public void setSalary(double empSal) {
      salary = empSal;
   }

   // This method prints the employee details.
   public void printEmp() {
      System.out.println("name  : " + name );
      System.out.println("salary :" + salary);
   }

   public static void main(String args[]) {
      Employee empOne = new Employee("Ransika");
      empOne.setSalary(1000);
      empOne.printEmp();
   }
}

이것은 다음 결과를 생성합니다-

산출

name  : Ransika
salary :1000.0

클래스 / 정적 변수

  • 정적 변수라고도하는 클래스 변수는 클래스에서 static 키워드로 선언되지만 메서드, 생성자 또는 블록 외부에 있습니다.

  • 생성 된 개체 수에 관계없이 클래스 당 각 클래스 변수의 복사본은 하나만 있습니다.

  • 정적 변수는 상수로 선언되는 것 외에는 거의 사용되지 않습니다. 상수는 public / private, final 및 static으로 선언 된 변수입니다. 상수 변수는 초기 값에서 변경되지 않습니다.

  • 정적 변수는 정적 메모리에 저장됩니다. final로 선언되고 공용 또는 개인 상수로 사용되는 정적 변수를 사용하는 경우는 거의 없습니다.

  • 정적 변수는 프로그램이 시작될 때 생성되고 프로그램이 중지 될 때 소멸됩니다.

  • 가시성은 인스턴스 변수와 유사합니다. 그러나 대부분의 정적 변수는 클래스 사용자가 사용할 수 있어야하므로 public으로 선언됩니다.

  • 기본값은 인스턴스 변수와 동일합니다. 숫자의 경우 기본값은 0입니다. 부울의 경우 거짓입니다. 개체 참조의 경우 null입니다. 선언 중 또는 생성자 내에서 값을 할당 할 수 있습니다. 또한 특수한 정적 초기화 블록에 값을 할당 할 수 있습니다.

  • 정적 변수는 ClassName.VariableName 클래스 이름으로 호출하여 액세스 할 수 있습니다 .

  • 클래스 변수를 public static final로 선언 할 때 변수 이름 (상수)은 모두 대문자입니다. 정적 변수가 공개 및 최종 변수가 아닌 경우 이름 지정 구문은 인스턴스 및 지역 변수와 동일합니다.

import java.io.*;
public class Employee {

   // salary  variable is a private static variable
   private static double salary;

   // DEPARTMENT is a constant
   public static final String DEPARTMENT = "Development ";

   public static void main(String args[]) {
      salary = 1000;
      System.out.println(DEPARTMENT + "average salary:" + salary);
   }
}

이것은 다음 결과를 생성합니다-

산출

Development average salary:1000

Note − 외부 클래스에서 변수에 액세스하는 경우 상수는 Employee.DEPARTMENT로 액세스해야합니다.

다음은 무엇입니까?

이 장에서 이미 액세스 수정 자 (공개 및 개인)를 사용했습니다. 다음 장에서는 액세스 수정 자 및 비 액세스 수정 자에 대해 자세히 설명합니다.

수정자는 의미를 변경하기 위해 해당 정의에 추가하는 키워드입니다. Java 언어에는 다음을 포함하여 다양한 수정자가 있습니다.

  • 자바 액세스 수정 자

  • 비 접근 수정 자

수정자를 사용하려면 클래스, 메서드 또는 변수 정의에 해당 키워드를 포함합니다. 수정자는 다음 예에서와 같이 명령문의 나머지 부분에 선행합니다.

public class className {
   // ...
}

private boolean myFlag;
static final double weeks = 9.5;
protected static final int BOXWIDTH = 42;

public static void main(String[] arguments) {
   // body of method
}

액세스 제어 수정 자

Java는 클래스, 변수, 메소드 및 생성자에 대한 액세스 수준을 설정하기위한 여러 액세스 수정자를 제공합니다. 네 가지 액세스 수준은-

  • 패키지에 표시되며 기본값입니다. 수정자가 필요하지 않습니다.
  • 수업 만 볼 수 있습니다 (비공개).
  • 전 세계에 공개 (공개).
  • 패키지 및 모든 하위 클래스에 표시됩니다 (보호됨).

비 액세스 수정 자

Java는 다른 많은 기능을 수행하기 위해 여러 비 액세스 수정자를 제공합니다.

  • 정적 클래스 방법 및 변수를 생성 개질제.

  • 최종 클래스, 메소드, 및 변수의 구현을 마무리 용 개질제.

  • 추상 추상 클래스와 메소드를 만들기위한 수정.

  • 동기화휘발성 스레드에 사용되는 수정.

다음은 무엇입니까?

다음 섹션에서는 Java 언어에서 사용되는 기본 연산자에 대해 설명합니다. 이 장에서는 애플리케이션 개발 중에 이러한 연산자를 사용하는 방법에 대한 개요를 제공합니다.

Java는 변수를 조작 할 수있는 풍부한 연산자 세트를 제공합니다. 모든 Java 연산자를 다음 그룹으로 나눌 수 있습니다.

  • 산술 연산자
  • 관계 연산자
  • 비트 연산자
  • 논리 연산자
  • 할당 연산자
  • 기타 연산자

산술 연산자

산술 연산자는 대수에서 사용되는 것과 같은 방식으로 수학 표현식에서 사용됩니다. 다음 표는 산술 연산자를 나열합니다-

정수 변수 A가 10을 보유하고 변수 B가 20을 보유한다고 가정하면-

예시보기

운영자 기술
+ (추가) 연산자의 양쪽에 값을 추가합니다. A + B는 30을 줄 것입니다
-(빼기) 왼쪽 피연산자에서 오른쪽 피연산자를 뺍니다. A-B는 -10을 줄 것입니다.
* (곱하기) 연산자의 양쪽에있는 값을 곱합니다. A * B는 200을 줄 것입니다
/ (나누기) 왼쪽 피연산자를 오른쪽 피연산자로 나눕니다. B / A는 2를 줄 것입니다
% (모듈러스) 왼쪽 피연산자를 오른쪽 피연산자로 나누고 나머지를 반환합니다. B % A는 0을 제공합니다.
++ (증가) 피연산자의 값을 1 씩 늘립니다. B ++는 21을 제공합니다.
-(감소) 피연산자의 값을 1 씩 줄입니다. B-- 19를 준다

관계 연산자

Java 언어에서 지원하는 다음과 같은 관계 연산자가 있습니다.

변수 A가 10을 보유하고 변수 B가 20을 보유한다고 가정하면-

예시보기

운영자 기술
== (같음) 두 피연산자의 값이 같은지 확인하고, 예이면 조건이 참이됩니다. (A == B)는 사실이 아닙니다.
! = (같지 않음) 두 피연산자의 값이 같은지 확인하고, 값이 같지 않으면 조건이 참이됩니다. (A! = B)는 사실입니다.
> (보다 큼) 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 큰지 확인하고, 그렇다면 조건이 참이됩니다. (A> B)는 사실이 아닙니다.
<(보다 작음) 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 작은 지 확인하고, 그렇다면 조건이 참이됩니다. (A <B)는 사실입니다.
> = (크거나 같음) 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 크거나 같은지 확인하고, 그렇다면 조건이 참이됩니다. (A> = B)는 사실이 아닙니다.
<= (작거나 같음) 왼쪽 피연산자의 값이 오른쪽 피연산자의 값보다 작거나 같은지 확인하고, 그렇다면 조건이 참이됩니다. (A <= B)는 참입니다.

비트 연산자

Java는 정수 유형, long, int, short, char 및 byte에 적용 할 수있는 여러 비트 연산자를 정의합니다.

비트 연산자는 비트에서 작동하고 비트 단위 연산을 수행합니다. a = 60이고 b = 13이라고 가정합니다. 이제 바이너리 형식으로 다음과 같이됩니다.

a = 0011 1100

b = 0000 1101

-----------------

a & b = 0000 1100

a | b = 0011 1101

a ^ b = 0011 0001

~ a = 1100 0011

다음 표는 비트 연산자를 나열합니다.

정수 변수 A가 60을 보유하고 변수 B가 13을 보유한다고 가정하면-

예시보기

운영자 기술
& (비트 및) 이진 AND 연산자는 두 피연산자에 모두있는 경우 결과에 비트를 복사합니다. (A & B)는 0000 1100 인 12를 줄 것입니다.
| (비트 OR) 이진 OR 연산자는 피연산자 중 하나에 있으면 비트를 복사합니다. (A | B)는 0011 1101 인 61을 제공합니다.
^ (비트 XOR) 이진 XOR 연산자는 하나의 피연산자에만 설정되어 있지만 둘 다에 설정되지 않은 경우 비트를 복사합니다. (A ^ B)는 0011 0001 인 49를 제공합니다.
~ (비트 칭찬) Binary Ones Complement Operator는 단항이며 비트를 '뒤집는'효과가 있습니다. (~ A)는 부호있는 이진수로 인해 2의 보수 형식으로 1100 0011 인 -61을 제공합니다.
<< (왼쪽 이동) 이진 왼쪽 시프트 연산자. 왼쪽 피연산자 값은 오른쪽 피연산자에 지정된 비트 수만큼 왼쪽으로 이동합니다. << 2는 1111 0000 인 240을 제공합니다.
>> (오른쪽 이동) 이진 오른쪽 시프트 연산자. 왼쪽 피연산자 값은 오른쪽 피연산자에 지정된 비트 수만큼 오른쪽으로 이동합니다. A >> 2는 1111 인 15를 제공합니다.
>>> (제로 채우기 오른쪽 시프트) 오른쪽 0 채우기 연산자를 시프트합니다. 왼쪽 피연산자 값은 오른쪽 피연산자에 지정된 비트 수만큼 오른쪽으로 이동하고 이동 된 값은 0으로 채워집니다. >>> 2는 0000 1111 인 15를 제공합니다.

논리 연산자

다음 표는 논리 연산자를 나열합니다-

부울 변수 A가 참이고 변수 B가 거짓이라고 가정하면-

예시보기

운영자 기술
&& (논리적 and) 논리 AND 연산자라고합니다. 두 피연산자가 모두 0이 아니면 조건이 참이됩니다. (A && B)는 거짓입니다.
|| (논리적 또는) 논리 OR 연산자라고합니다. 두 피연산자 중 하나가 0이 아니면 조건이 참이됩니다. (A || B) 참
! (논리적 아님) 논리 NOT 연산자라고합니다. 피연산자의 논리 상태를 반전하는 데 사용합니다. 조건이 참이면 논리 NOT 연산자는 거짓으로 만듭니다. ! (A && B)가 참

할당 연산자

다음은 Java 언어에서 지원하는 할당 연산자입니다-

예시보기

운영자 기술
= 간단한 할당 연산자. 오른쪽 피연산자의 값을 왼쪽 피연산자에 할당합니다. C = A + B는 A + B의 값을 C에 할당합니다.
+ = AND 할당 연산자를 추가합니다. 왼쪽 피연산자에 오른쪽 피연산자를 추가하고 결과를 왼쪽 피연산자에 할당합니다. C + = A는 C = C + A와 같습니다.
-= AND 할당 연산자를 뺍니다. 왼쪽 피연산자에서 오른쪽 피연산자를 빼고 결과를 왼쪽 피연산자에 할당합니다. C-= A는 C = C – A와 같습니다.
* = 곱하기 AND 할당 연산자. 오른쪽 피연산자와 왼쪽 피연산자를 곱하고 결과를 왼쪽 피연산자에 할당합니다. C * = A는 C = C * A와 같습니다.
/ = AND 할당 연산자를 나눕니다. 왼쪽 피연산자를 오른쪽 피연산자로 나누고 결과를 왼쪽 피연산자에 할당합니다. C / = A는 C = C / A와 같습니다.
% = 계수 AND 할당 연산자. 두 개의 피연산자를 사용하여 모듈러스를 취하고 결과를 왼쪽 피연산자에 할당합니다. C % = A는 C = C % A와 동일합니다.
<< = 왼쪽 시프트 AND 할당 연산자. C << = 2는 C = C << 2와 동일합니다.
>> = 오른쪽 시프트 AND 할당 연산자. C >> = 2는 C = C >> 2와 동일합니다.
& = 비트 AND 대입 연산자. C & = 2는 C = C & 2와 동일합니다.
^ = 비트 배타적 OR 및 할당 연산자. C ^ = 2는 C = C ^ 2와 같습니다.
| = 비트 포함 OR 및 할당 연산자. C | = 2는 C = C | 2

기타 연산자

Java 언어에서 지원하는 다른 연산자는 거의 없습니다.

조건부 연산자 (? :)

조건부 연산자는 ternary operator. 이 연산자는 세 개의 피연산자로 구성되며 부울 표현식을 평가하는 데 사용됩니다. 연산자의 목표는 변수에 할당 할 값을 결정하는 것입니다. 연산자는 다음과 같이 작성됩니다.

variable x = (expression) ? value if true : value if false

다음은 예입니다-

Example

public class Test {

   public static void main(String args[]) {
      int a, b;
      a = 10;
      b = (a == 1) ? 20: 30;
      System.out.println( "Value of b is : " +  b );

      b = (a == 10) ? 20: 30;
      System.out.println( "Value of b is : " + b );
   }
}

이것은 다음 결과를 생성합니다-

Output

Value of b is : 30
Value of b is : 20

instanceof 연산자

이 연산자는 개체 참조 변수에만 사용됩니다. 연산자는 객체가 특정 유형 (클래스 유형 또는 인터페이스 유형)인지 확인합니다. instanceof 연산자는-

( Object reference variable ) instanceof  (class/interface type)

연산자 왼쪽의 변수가 참조하는 객체가 오른쪽의 클래스 / 인터페이스 유형에 대한 IS-A 검사를 통과하면 결과가 참이됩니다. 다음은 예입니다-

Example

public class Test {

   public static void main(String args[]) {

      String name = "James";

      // following will return true since name is type of String
      boolean result = name instanceof String;
      System.out.println( result );
   }
}

이것은 다음 결과를 생성합니다-

Output

true

이 연산자는 비교되는 객체가 오른쪽 유형과 호환되는 할당 인 경우 여전히 true를 반환합니다. 다음은 또 하나의 예입니다.

Example

class Vehicle {}

public class Car extends Vehicle {

   public static void main(String args[]) {

      Vehicle a = new Car();
      boolean result =  a instanceof Car;
      System.out.println( result );
   }
}

이것은 다음 결과를 생성합니다-

Output

true

Java 연산자의 우선 순위

연산자 우선 순위는 식의 용어 그룹화를 결정합니다. 이는식이 평가되는 방식에 영향을줍니다. 특정 연산자는 다른 연산자보다 우선 순위가 높습니다. 예를 들어 곱셈 연산자는 더하기 연산자보다 우선 순위가 높습니다.

예를 들어, x = 7 + 3 * 2; 여기서 x는 20이 아니라 13으로 할당됩니다. 연산자 *는 +보다 우선 순위가 높기 때문에 먼저 3 * 2를 곱한 다음 7에 더합니다.

여기에서 우선 순위가 가장 높은 연산자는 테이블 맨 위에 표시되고 가장 낮은 연산자는 맨 아래에 표시됩니다. 식 내에서 우선 순위가 높은 연산자가 먼저 평가됩니다.

범주 운영자 연관성
접미사 표현 ++ 표현- 좌에서 우로
단항 ++ 식 –- 식 + 식 – 식 ~! 오른쪽에서 왼쪽으로
곱셈 * / % 좌에서 우로
첨가물 +- 좌에서 우로
시프트 << >> >>> 좌에서 우로
관계형 <> <=> = instanceof 좌에서 우로
평등 ==! = 좌에서 우로
비트 AND & 좌에서 우로
비트 XOR ^ 좌에서 우로
비트 OR | 좌에서 우로
논리적 AND && 좌에서 우로
논리적 OR || 좌에서 우로
가정 어구 ? : 오른쪽에서 왼쪽으로
할당 = + =-= * = / = % = ^ = | = << = >> = >>> = 오른쪽에서 왼쪽으로

다음은 무엇입니까?

다음 장에서는 Java 프로그래밍의 루프 제어에 대해 설명합니다. 이 장에서는 다양한 유형의 루프와 이러한 루프를 Java 프로그램 개발에 사용하는 방법과 사용 목적에 대해 설명합니다.

코드 블록을 여러 번 실행해야하는 상황이있을 수 있습니다. 일반적으로 명령문은 순차적으로 실행됩니다. 함수의 첫 번째 명령문이 먼저 실행되고 두 번째 명령문이 실행되는 식입니다.

프로그래밍 언어는보다 복잡한 실행 경로를 허용하는 다양한 제어 구조를 제공합니다.

loop 문을 사용하면 문 또는 문 그룹을 여러 번 실행할 수 있으며 다음은 대부분의 프로그래밍 언어에서 루프 문의 일반적인 형식입니다.

Java 프로그래밍 언어는 루핑 요구 사항을 처리하기 위해 다음 유형의 루프를 제공합니다. 세부 사항을 확인하려면 다음 링크를 클릭하십시오.

Sr. 아니. 루프 및 설명
1 while 루프

주어진 조건이 참인 동안 명령문 또는 명령문 그룹을 반복합니다. 루프 본문을 실행하기 전에 조건을 테스트합니다.

2 for 루프

일련의 문을 여러 번 실행하고 루프 변수를 관리하는 코드를 축약합니다.

do ... while 루프

while 문과 비슷하지만 루프 본문의 끝에서 조건을 테스트한다는 점이 다릅니다.

루프 제어문

루프 제어문은 정상적인 순서에서 실행을 변경합니다. 실행이 범위를 벗어나면 해당 범위에서 생성 된 모든 자동 개체가 삭제됩니다.

Java는 다음 제어문을 지원합니다. 세부 사항을 확인하려면 다음 링크를 클릭하십시오.

Sr. 아니. 제어문 및 설명
1 break 문

종료 loop 또는 switch 문을 열고 루프 또는 스위치 바로 다음 문으로 실행을 전송합니다.

2 계속 진술

루프가 본문의 나머지 부분을 건너 뛰고 반복하기 전에 즉시 상태를 다시 테스트하도록합니다.

Java의 향상된 for 루프

Java 5부터 향상된 for 루프가 도입되었습니다. 주로 배열을 포함한 요소 모음을 탐색하는 데 사용됩니다.

통사론

다음은 향상된 for 루프의 구문입니다.

for(declaration : expression) {
   // Statements
}
  • Declaration− 새로 선언 된 블록 변수는 액세스하는 배열의 요소와 호환되는 유형입니다. 변수는 for 블록 내에서 사용할 수 있으며 해당 값은 현재 배열 요소와 동일합니다.

  • Expression− 이것은 반복해야하는 배열로 평가됩니다. 식은 배열을 반환하는 배열 변수 또는 메서드 호출 일 수 있습니다.

public class Test {

   public static void main(String args[]) {
      int [] numbers = {10, 20, 30, 40, 50};

      for(int x : numbers ) {
         System.out.print( x );
         System.out.print(",");
      }
      System.out.print("\n");
      String [] names = {"James", "Larry", "Tom", "Lacy"};

      for( String name : names ) {
         System.out.print( name );
         System.out.print(",");
      }
   }
}

이것은 다음 결과를 생성합니다-

산출

10, 20, 30, 40, 50,
James, Larry, Tom, Lacy,

다음은 무엇입니까?

다음 장에서 우리는 자바 프로그래밍의 의사 결정문에 대해 배울 것입니다.

의사 결정 구조에는 조건이 참인 경우 실행될 명령문과 함께 프로그램이 평가하거나 테스트 할 하나 이상의 조건이 있으며, 조건이 판별되면 실행될 다른 명령문도 선택적으로 포함됩니다. 거짓입니다.

다음은 대부분의 프로그래밍 언어에서 발견되는 일반적인 의사 결정 구조의 일반적인 형태입니다.

Java 프로그래밍 언어는 다음 유형의 의사 결정문을 제공합니다. 세부 사항을 확인하려면 다음 링크를 클릭하십시오.

Sr. 아니. 성명 및 설명
1 if 문

if statement 부울 표현식과 하나 이상의 문으로 구성됩니다.

2 if ... else 문

if statement 뒤에 선택 사항이 올 수 있습니다. else statement, 부울 표현식이 false 일 때 실행됩니다.

중첩 된 if 문

하나를 사용할 수 있습니다 if 또는 else if 다른 내부의 진술 if 또는 else if 진술 (들).

4 switch 문

switch 문을 사용하면 변수가 값 목록과 같은지 테스트 할 수 있습니다.

? : 운영자

우리는 conditional operator ? : 대체하는 데 사용할 수있는 이전 장에서 if...else진술. 그것은 다음과 같은 일반적인 형태를 가지고 있습니다-

Exp1 ? Exp2 : Exp3;

Exp1, Exp2 및 Exp3은 표현식입니다. 콜론의 사용과 배치에 주목하십시오.

전체 표현식의 값을 결정하기 위해 처음에 exp1이 평가됩니다.

  • exp1의 값이 참이면 Exp2의 값은 전체 표현식의 값이됩니다.

  • exp1의 값이 false이면 Exp3이 평가되고 해당 값이 전체 표현식의 값이됩니다.

다음은 무엇입니까?

다음 장에서는 Number 클래스 (java.lang 패키지에 있음)와 Java 언어의 하위 클래스에 대해 설명합니다.

기본 데이터 유형이 아닌 이러한 클래스의 인스턴스화를 사용할 상황과 Numbers로 작업 할 때 알아야하는 형식화, 수학 함수와 같은 클래스를 살펴볼 것입니다.

일반적으로 Numbers로 작업 할 때 byte, int, long, double 등과 같은 원시 데이터 유형을 사용합니다.

int i = 5000;
float gpa = 13.65f;
double mask = 125;

그러나 개발 과정에서 원시 데이터 유형 대신 객체를 사용해야하는 상황이 발생합니다. 이를 달성하기 위해 Java는wrapper classes.

모든 래퍼 클래스 (Integer, Long, Byte, Double, Float, Short)는 추상 클래스 Number의 하위 클래스입니다.

래퍼 클래스의 객체는 각각의 기본 데이터 유형을 포함하거나 래핑합니다. 원시 데이터 유형을 객체로 변환하는 것이 호출됩니다.boxing, 이것은 컴파일러에 의해 처리됩니다. 따라서 래퍼 클래스를 사용하는 동안 기본 데이터 유형의 값을 Wrapper 클래스의 생성자에 전달하기 만하면됩니다.

그리고 Wrapper 객체는 다시 원시 데이터 유형으로 변환되며이 프로세스를 unboxing이라고합니다. 그만큼Number 클래스는 java.lang 패키지의 일부입니다.

다음은 권투 및 개봉의 예입니다-

public class Test {

   public static void main(String args[]) {
      Integer x = 5; // boxes int to an Integer object
      x =  x + 10;   // unboxes the Integer to a int
      System.out.println(x); 
   }
}

이것은 다음 결과를 생성합니다-

산출

15

x에 정수 값이 할당되면 x가 정수 객체이므로 컴파일러는 정수를 상자에 넣습니다. 나중에 x는 정수로 추가 될 수 있도록 unboxed됩니다.

번호 방법

다음은 Number 클래스의 모든 하위 클래스가 구현하는 인스턴스 메서드 목록입니다.

Sr. 아니. 방법 및 설명
1 xxxValue ()

Number 개체 의 값을 xxx 데이터 형식으로 변환하고 반환합니다.

2 compareTo ()

Number 객체를 인수와 비교 합니다 .

같음 ()

숫자 개체가 인수와 같은지 여부를 확인합니다 .

4 valueOf ()

지정된 프리미티브의 값을 보유하는 Integer 객체를 반환합니다.

5 toString ()

지정된 int 또는 Integer의 값을 나타내는 String 개체를 반환합니다.

6 parseInt ()

이 메소드는 특정 문자열의 기본 데이터 유형을 가져 오는 데 사용됩니다.

7 abs ()

인수의 절대 값을 반환합니다.

8 올림()

인수보다 크거나 같은 가장 작은 정수를 반환합니다. 이중으로 반환됩니다.

9 바닥()

인수보다 작거나 같은 가장 큰 정수를 반환합니다. 이중으로 반환됩니다.

10 rint ()

인수 값에서 가장 가까운 정수를 반환합니다. 이중으로 반환됩니다.

11 일주()

인수에 대한 메서드의 반환 유형에 표시된대로 가장 가까운 long 또는 int를 반환합니다.

12 min ()

두 인수 중 더 작은 인수를 반환합니다.

13 max ()

두 인수 중 더 큰 값을 반환합니다.

14 exp ()

자연 로그 e의 밑을 인수의 거듭 제곱으로 반환합니다.

15 로그()

인수의 자연 로그를 반환합니다.

16 펑 ()

두 번째 인수로 거듭 제곱 한 첫 번째 인수의 값을 반환합니다.

17 sqrt ()

인수의 제곱근을 반환합니다.

18 죄()

지정된 double 값의 사인을 반환합니다.

19 코사인()

지정된 double 값의 코사인을 반환합니다.

20 탠 껍질()

지정된 double 값의 탄젠트를 반환합니다.

21 asin ()

지정된 double 값의 아크 사인을 반환합니다.

22 acos ()

지정된 double 값의 아크 코사인을 반환합니다.

23 atan ()

지정된 double 값의 아크 탄젠트를 반환합니다.

24 atan2 ()

직사각형 좌표 (x, y)를 극좌표 (r, theta)로 변환하고 theta를 반환합니다.

25 toDegrees ()

인수를 각도로 변환합니다.

26 toRadians ()

인수를 라디안으로 변환합니다.

27 랜덤 ()

난수를 반환합니다.

다음은 무엇입니까?

다음 섹션에서는 Java의 Character 클래스를 살펴 보겠습니다. Java에서 객체 문자 및 기본 데이터 유형 char을 사용하는 방법을 배우게됩니다.

일반적으로 문자로 작업 할 때 원시 데이터 유형 char을 사용합니다.

char ch = 'a';

// Unicode for uppercase Greek omega character
char uniChar = '\u039A'; 

// an array of chars
char[] charArray ={ 'a', 'b', 'c', 'd', 'e' };

그러나 개발 과정에서 원시 데이터 유형 대신 객체를 사용해야하는 상황이 발생합니다. 이를 달성하기 위해 Java는 래퍼 클래스를 제공합니다.Character 원시 데이터 유형 char의 경우.

Character 클래스는 문자를 조작하는 데 유용한 여러 클래스 (즉, 정적) 메서드를 제공합니다. Character 생성자로 Character 객체를 만들 수 있습니다.

Character ch = new Character('a');

Java 컴파일러는 또한 일부 상황에서 문자 객체를 생성합니다. 예를 들어, 객체를 예상하는 메서드에 기본 문자를 전달하면 컴파일러가 자동으로 문자를 문자로 변환합니다. 이 기능을 오토 박싱 또는 언 박싱이라고합니다.

// Here following primitive char 'a'
// is boxed into the Character object ch
Character ch = 'a';

// Here primitive 'x' is boxed for method test,
// return is unboxed to char 'c'
char c = test('x');

탈출 시퀀스

백 슬래시 (\)가 앞에 오는 문자는 이스케이프 시퀀스이며 컴파일러에서 특별한 의미를 갖습니다.

줄 바꿈 문자 (\ n)는 문자열이 인쇄 된 후 다음 줄로 이동하기 위해 System.out.println () 문에서이 자습서에서 자주 사용되었습니다.

다음 표는 자바 이스케이프 시퀀스를 보여줍니다-

탈출 시퀀스 기술
\티 이 시점에서 텍스트에 탭을 삽입합니다.
\비 이 시점에서 텍스트에 백 스페이스를 삽입합니다.
\엔 이 시점에서 텍스트에 개행을 삽입합니다.
\아르 자형 이 시점에서 텍스트에 캐리지 리턴을 삽입합니다.
\에프 이 시점에서 텍스트에 양식 피드를 삽입합니다.
\ ' 이 시점에서 텍스트에 작은 따옴표 문자를 삽입합니다.
\ " 이 시점에서 텍스트에 큰 따옴표 문자를 삽입합니다.
\\ 이 시점에서 텍스트에 백 슬래시 문자를 삽입합니다.

print 문에서 이스케이프 시퀀스가 ​​발견되면 컴파일러가 그에 따라 해석합니다.

따옴표 안에 따옴표를 넣으려면 내부 따옴표에 이스케이프 시퀀스 \ "를 사용해야합니다.

public class Test {

   public static void main(String args[]) {
      System.out.println("She said \"Hello!\" to me.");
   }
}

이것은 다음 결과를 생성합니다-

산출

She said "Hello!" to me.

캐릭터 방법

다음은 Character 클래스의 모든 하위 클래스가 구현하는 중요한 인스턴스 메서드 목록입니다.

Sr. 아니. 방법 및 설명
1 isLetter ()

지정된 char 값이 문자인지 여부를 확인합니다.

2 isDigit ()

지정된 char 값이 숫자인지 확인합니다.

isWhitespace ()

지정된 char 값이 공백인지 여부를 확인합니다.

4 isUpperCase ()

지정된 char 값이 대문자인지 여부를 확인합니다.

5 isLowerCase ()

지정된 char 값이 소문자인지 여부를 확인합니다.

6 toUpperCase ()

지정된 char 값의 대문자 형식을 반환합니다.

7 toLowerCase ()

지정된 char 값의 소문자 형식을 반환합니다.

8 toString ()

지정된 문자 값, 즉 한 문자 문자열을 나타내는 String 개체를 반환합니다.

전체 메소드 목록은 java.lang.Character API 사양을 참조하십시오.

다음은 무엇입니까?

다음 섹션에서는 Java의 String 클래스를 살펴 보겠습니다. 문자열을 효율적으로 선언하고 사용하는 방법과 String 클래스의 몇 가지 중요한 메서드를 배우게됩니다.

Java 프로그래밍에서 널리 사용되는 문자열은 일련의 문자입니다. Java 프로그래밍 언어에서 문자열은 객체로 처리됩니다.

Java 플랫폼은 문자열을 만들고 조작 할 수있는 String 클래스를 제공합니다.

문자열 만들기

문자열을 만드는 가장 직접적인 방법은 다음과 같습니다.

String greeting = "Hello world!";

코드에서 문자열 리터럴을 발견 할 때마다 컴파일러는이 경우 "Hello world!"값을 사용하여 String 개체를 만듭니다.

다른 객체와 마찬가지로 new 키워드와 생성자를 사용하여 String 객체를 만들 수 있습니다. String 클래스에는 문자 배열과 같은 다른 소스를 사용하여 문자열의 초기 값을 제공 할 수있는 11 개의 생성자가 있습니다.

public class StringDemo {

   public static void main(String args[]) {
      char[] helloArray = { 'h', 'e', 'l', 'l', 'o', '.' };
      String helloString = new String(helloArray);  
      System.out.println( helloString );
   }
}

이것은 다음 결과를 생성합니다-

산출

hello.

Note− String 클래스는 불변이므로 일단 생성되면 String 객체를 변경할 수 없습니다. 문자열을 많이 수정해야하는 경우 문자열 버퍼 및 문자열 빌더 클래스 를 사용해야합니다 .

문자열 길이

객체에 대한 정보를 얻는 데 사용되는 방법은 다음과 같습니다. accessor methods. 문자열과 함께 사용할 수있는 접근 자 메서드 중 하나는 문자열 개체에 포함 된 문자 수를 반환하는 length () 메서드입니다.

다음 프로그램은 length(), 메서드 String 클래스.

public class StringDemo {

   public static void main(String args[]) {
      String palindrome = "Dot saw I was Tod";
      int len = palindrome.length();
      System.out.println( "String Length is : " + len );
   }
}

이것은 다음 결과를 생성합니다-

산출

String Length is : 17

문자열 연결

String 클래스는 두 문자열을 연결하는 방법을 포함합니다-

string1.concat(string2);

이것은 끝에 string2가 추가 된 string1 인 새 문자열을 리턴합니다. 다음과 같이 문자열 리터럴과 함께 concat () 메서드를 사용할 수도 있습니다.

"My name is ".concat("Zara");

문자열은 일반적으로 −에서와 같이 + 연산자로 연결됩니다.

"Hello," + " world" + "!"

결과는-

"Hello, world!"

다음 예를 살펴 보겠습니다.

public class StringDemo {

   public static void main(String args[]) {
      String string1 = "saw I was ";
      System.out.println("Dot " + string1 + "Tod");
   }
}

이것은 다음 결과를 생성합니다-

산출

Dot saw I was Tod

형식 문자열 생성

형식이 지정된 숫자로 출력을 인쇄하는 printf () 및 format () 메서드가 있습니다. String 클래스에는 PrintStream 객체가 아닌 String 객체를 반환하는 동등한 클래스 메서드 인 format ()이 있습니다.

String의 정적 format () 메서드를 사용하면 일회용 print 문과 달리 재사용 할 수있는 형식화 된 문자열을 만들 수 있습니다. 예를 들어, 대신-

System.out.printf("The value of the float variable is " +
                  "%f, while the value of the integer " +
                  "variable is %d, and the string " +
                  "is %s", floatVar, intVar, stringVar);

당신은 쓸 수 있습니다-

String fs;
fs = String.format("The value of the float variable is " +
                   "%f, while the value of the integer " +
                   "variable is %d, and the string " +
                   "is %s", floatVar, intVar, stringVar);
System.out.println(fs);

문자열 방법

다음은 String 클래스에서 지원하는 메소드 목록입니다.

Sr. 아니. 방법 및 설명
1 char charAt (int 인덱스)

지정된 인덱스에있는 문자를 반환합니다.

2 int compareTo (Object o)

이 String을 다른 Object와 비교합니다.

int compareTo (String anotherString)

두 문자열을 사전 순으로 비교합니다.

4 int compareToIgnoreCase (문자열 str)

대소 문자 차이를 무시하고 사전 식으로 두 문자열을 비교합니다.

5 문자열 연결 (문자열 str)

지정된 문자열을이 문자열의 끝에 연결합니다.

6 부울 contentEquals (StringBuffer sb)

이 String이 지정된 StringBuffer와 동일한 문자 시퀀스를 나타내는 경우에만 true를 리턴합니다.

7 정적 문자열 copyValueOf (char [] 데이터)

지정된 배열의 문자 시퀀스를 나타내는 문자열을 반환합니다.

8 static String copyValueOf (char [] data, int offset, int count)

지정된 배열의 문자 시퀀스를 나타내는 문자열을 반환합니다.

9 부울 endsWith (문자열 접미사)

이 문자열이 지정된 접미사로 끝나는 지 테스트합니다.

10 부울 같음 (Object anObject)

이 문자열을 지정된 개체와 비교합니다.

11 부울 equalsIgnoreCase (String anotherString)

대소 문자 고려 사항을 무시하고이 문자열을 다른 문자열과 비교합니다.

12 바이트 getBytes ()

플랫폼의 기본 문자 집합을 사용하여이 문자열을 바이트 시퀀스로 인코딩하고 결과를 새 바이트 배열에 저장합니다.

13 byte [] getBytes (문자열 charsetName)

명명 된 문자 집합을 사용하여이 문자열을 바이트 시퀀스로 인코딩하고 결과를 새 바이트 배열에 저장합니다.

14 void getChars (int srcBegin, int srcEnd, char [] dst, int dstBegin)

이 문자열의 문자를 대상 문자 배열로 복사합니다.

15 int hashCode ()

이 문자열의 해시 코드를 반환합니다.

16 int indexOf (int ch)

이 문자열 내에서 지정된 문자가 처음 나타나는 인덱스를 반환합니다.

17 int indexOf (int ch, int fromIndex)

지정된 인덱스에서 검색을 시작하여 지정된 문자가 처음 나타나는이 문자열 내의 인덱스를 반환합니다.

18 int indexOf (문자열 str)

이 문자열 내에서 지정된 하위 문자열의 첫 번째 발생 인덱스를 반환합니다.

19 int indexOf (문자열 str, int fromIndex)

지정된 인덱스에서 시작하여 지정된 하위 문자열이 처음 나타나는이 문자열 내의 인덱스를 반환합니다.

20 문자열 intern ()

문자열 객체에 대한 정식 표현을 반환합니다.

21 int lastIndexOf (int ch)

이 문자열 내에서 지정된 문자의 마지막 발생 인덱스를 반환합니다.

22 int lastIndexOf (int ch, int fromIndex)

지정된 인덱스에서 시작하여 역방향으로 검색하여 지정된 문자가 마지막으로 나타나는이 문자열 내의 인덱스를 반환합니다.

23 int lastIndexOf (문자열 str)

이 문자열 내에서 지정된 부분 문자열의 가장 오른쪽에있는 인덱스를 반환합니다.

24 int lastIndexOf (문자열 str, int fromIndex)

지정된 인덱스에서 시작하여 역방향으로 검색하여 지정된 하위 문자열의 마지막 발생에 대한이 문자열 내의 인덱스를 반환합니다.

25 int 길이 ()

이 문자열의 길이를 반환합니다.

26 부울 일치 (문자열 정규식)

이 문자열이 주어진 정규식과 일치하는지 여부를 알려줍니다.

27 부울 regionMatches (boolean ignoreCase, int toffset, String other, int ooffset, int len)

두 문자열 영역이 같은지 테스트합니다.

28 부울 regionMatches (int toffset, 기타 문자열, int ooffset, int len)

두 문자열 영역이 같은지 테스트합니다.

29 문자열 바꾸기 (char oldChar, char newChar)

이 문자열의 모든 oldChar 항목을 newChar로 교체 한 결과 새 문자열을 반환합니다.

30 String replaceAll (문자열 정규식, 문자열 대체

주어진 정규식과 일치하는이 문자열의 각 부분 문자열을 주어진 대체로 바꿉니다.

31 문자열 replaceFirst (문자열 정규식, 문자열 대체)

지정된 정규식과 일치하는이 문자열의 첫 번째 하위 문자열을 지정된 대체로 바꿉니다.

32 문자열 [] split (문자열 정규식)

주어진 정규식과 일치하는 부분을 중심으로이 문자열을 분할합니다.

33 문자열 [] split (문자열 정규식, 정수 제한)

주어진 정규식과 일치하는 부분을 중심으로이 문자열을 분할합니다.

34 부울 startsWith (문자열 접두사)

이 문자열이 지정된 접두사로 시작하는지 테스트합니다.

35 부울 startsWith (문자열 접두사, 정수 toffset)

이 문자열이 지정된 인덱스를 시작하는 지정된 접두사로 시작하는지 테스트합니다.

36 CharSequence subSequence (int beginIndex, int endIndex)

이 시퀀스의 하위 시퀀스 인 새 문자 시퀀스를 반환합니다.

37 문자열 부분 문자열 (int beginIndex)

이 문자열의 하위 문자열 인 새 문자열을 반환합니다.

38 문자열 부분 문자열 (int beginIndex, int endIndex)

이 문자열의 하위 문자열 인 새 문자열을 반환합니다.

39 char [] toCharArray ()

이 문자열을 새 문자 배열로 변환합니다.

40 String toLowerCase ()

기본 로케일의 규칙을 사용하여이 문자열의 모든 문자를 소문자로 변환합니다.

41 String toLowerCase (로케일 로케일)

지정된 로케일의 규칙을 사용하여이 문자열의 모든 문자를 소문자로 변환합니다.

42 문자열 toString ()

이 객체 (이미 문자열입니다!) 자체가 반환됩니다.

43 문자열 toUpperCase ()

기본 로케일의 규칙을 사용하여이 문자열의 모든 문자를 대문자로 변환합니다.

44 String toUpperCase (로케일 로케일)

지정된 로케일의 규칙을 사용하여이 문자열의 모든 문자를 대문자로 변환합니다.

45 문자열 trim ()

선행 및 후행 공백이 생략 된 문자열의 복사본을 반환합니다.

46 static String valueOf (기본 데이터 유형 x)

전달 된 데이터 유형 인수의 문자열 표현을 반환합니다.

Java는 데이터 구조를 제공합니다. array, 동일한 유형의 요소의 고정 크기 순차 컬렉션을 저장합니다. 배열은 데이터 모음을 저장하는 데 사용되지만 배열을 동일한 유형의 변수 모음으로 생각하는 것이 더 유용합니다.

number0, number1, ..., number99와 같은 개별 변수를 선언하는 대신 숫자와 같은 하나의 배열 변수를 선언하고 numbers [0], numbers [1] 및 ..., numbers [99]를 사용하여 개별 변수.

이 자습서에서는 인덱스 변수를 사용하여 배열 변수를 선언하고, 배열을 만들고, 배열을 처리하는 방법을 소개합니다.

배열 변수 선언

프로그램에서 배열을 사용하려면 배열을 참조 할 변수를 선언해야하며 변수가 참조 할 수있는 배열 유형을 지정해야합니다. 다음은 배열 변수를 선언하는 구문입니다.

통사론

dataType[] arrayRefVar;   // preferred way.
or
dataType arrayRefVar[];  // works but not preferred way.

Note − 스타일 dataType[] arrayRefVar선호됩니다. 스타일dataType arrayRefVar[] C / C ++ 언어에서 비롯되었으며 C / C ++ 프로그래머를 수용하기 위해 Java에서 채택되었습니다.

다음 코드 조각은이 구문의 예입니다.

double[] myList;   // preferred way.
or
double myList[];   // works but not preferred way.

배열 생성

다음 구문으로 new 연산자를 사용하여 배열을 만들 수 있습니다.

통사론

arrayRefVar = new dataType[arraySize];

위의 진술은 두 가지를 수행합니다.

  • new dataType [arraySize]를 사용하여 배열을 생성합니다.

  • 새로 생성 된 배열의 참조를 변수 arrayRefVar에 할당합니다.

배열 변수를 선언하고, 배열을 만들고, 배열의 참조를 변수에 할당하는 것은 아래와 같이 하나의 문으로 결합 될 수 있습니다.

dataType[] arrayRefVar = new dataType[arraySize];

또는 다음과 같이 배열을 만들 수 있습니다-

dataType[] arrayRefVar = {value0, value1, ..., valuek};

배열 요소는 index. 배열 인덱스는 0부터 시작합니다. 즉, 0에서 시작하여arrayRefVar.length-1.

다음 명령문은 배열 변수 myList를 선언하고 이중 유형의 10 개 요소 배열을 생성하고 myList에 대한 참조를 할당합니다.

double[] myList = new double[10];

다음 그림은 myList 배열을 나타냅니다. 여기에서 myList는 10 개의 double 값을 보유하고 인덱스는 0에서 9까지입니다.

배열 처리

배열 요소를 처리 할 때 종종 다음 중 하나를 사용합니다. for 루프 또는 foreach 루프의 모든 요소가 동일한 유형이고 배열의 크기를 알고 있기 때문입니다.

다음은 배열을 생성, 초기화 및 처리하는 방법을 보여주는 완전한 예입니다.

public class TestArray {

   public static void main(String[] args) {
      double[] myList = {1.9, 2.9, 3.4, 3.5};

      // Print all the array elements
      for (int i = 0; i < myList.length; i++) {
         System.out.println(myList[i] + " ");
      }
     
      // Summing all elements
      double total = 0;
      for (int i = 0; i < myList.length; i++) {
         total += myList[i];
      }
      System.out.println("Total is " + total);
      
      // Finding the largest element
      double max = myList[0];
      for (int i = 1; i < myList.length; i++) {
         if (myList[i] > max) max = myList[i];
      }
      System.out.println("Max is " + max);  
   }
}

이것은 다음 결과를 생성합니다-

산출

1.9
2.9
3.4
3.5
Total is 11.7
Max is 3.5

foreach 루프

JDK 1.5는 인덱스 변수를 사용하지 않고 전체 배열을 순차적으로 순회 할 수있는 foreach 루프 또는 향상된 for 루프로 알려진 새로운 for 루프를 도입했습니다.

다음 코드는 배열 myList의 모든 요소를 ​​표시합니다-

public class TestArray {

   public static void main(String[] args) {
      double[] myList = {1.9, 2.9, 3.4, 3.5};

      // Print all the array elements
      for (double element: myList) {
         System.out.println(element);
      }
   }
}

이것은 다음 결과를 생성합니다-

산출

1.9
2.9
3.4
3.5

메서드에 배열 전달

기본 유형 값을 메서드에 전달할 수있는 것처럼 배열을 메서드에 전달할 수도 있습니다. 예를 들어, 다음 메서드는int 배열-

public static void printArray(int[] array) {
   for (int i = 0; i < array.length; i++) {
      System.out.print(array[i] + " ");
   }
}

배열을 전달하여 호출 할 수 있습니다. 예를 들어 다음 문은 printArray 메서드를 호출하여 3, 1, 2, 6, 4, 2를 표시합니다.

printArray(new int[]{3, 1, 2, 6, 4, 2});

메서드에서 배열 반환

메서드는 배열을 반환 할 수도 있습니다. 예를 들어, 다음 메서드는 다른 배열의 반전 인 배열을 반환합니다.

public static int[] reverse(int[] list) {
   int[] result = new int[list.length];

   for (int i = 0, j = result.length - 1; i < list.length; i++, j--) {
      result[j] = list[i];
   }
   return result;
}

Arrays 클래스

java.util.Arrays 클래스에는 배열 정렬 및 검색, 배열 비교 및 ​​배열 요소 채우기를위한 다양한 정적 메소드가 포함되어 있습니다. 이러한 메서드는 모든 기본 형식에 대해 오버로드됩니다.

Sr. 아니. 방법 및 설명
1

public static int binarySearch(Object[] a, Object key)

이진 검색 알고리즘을 사용하여 지정된 Object 배열 (Byte, Int, double 등)에서 지정된 값을 검색합니다. 이 호출을하기 전에 배열을 정렬해야합니다. 목록에 포함 된 경우 검색 키의 인덱스를 반환합니다. 그렇지 않으면 (– (삽입 지점 + 1))을 반환합니다.

2

public static boolean equals(long[] a, long[] a2)

지정된 두 long 배열이 서로 같으면 true를 반환합니다. 두 배열에 동일한 수의 요소가 포함되어 있고 두 배열에서 해당하는 모든 요소 쌍이 동일한 경우 두 배열은 동일한 것으로 간주됩니다. 두 배열이 같으면 true를 반환합니다. 다른 모든 기본 데이터 유형 (Byte, short, Int 등)에서 동일한 방법을 사용할 수 있습니다.

public static void fill(int[] a, int val)

지정된 int 배열의 각 요소에 지정된 int 값을 할당합니다. 다른 모든 기본 데이터 유형 (Byte, short, Int 등)에서 동일한 방법을 사용할 수 있습니다.

4

public static void sort(Object[] a)

요소의 자연스러운 순서에 따라 지정된 개체 배열을 오름차순으로 정렬합니다. 다른 모든 기본 데이터 유형 (Byte, short, Int 등)에서 동일한 방법을 사용할 수 있습니다.

Java는 Date 수업 가능 java.util 패키지에서이 클래스는 현재 날짜와 시간을 캡슐화합니다.

Date 클래스는 다음 표와 같이 두 개의 생성자를 지원합니다.

Sr. 아니. 생성자 및 설명
1

Date( )

이 생성자는 현재 날짜 및 시간으로 개체를 초기화합니다.

2

Date(long millisec)

이 생성자는 1970 년 1 월 1 일 자정 이후 경과 된 밀리 초 수와 같은 인수를받습니다.

다음은 날짜 클래스의 메서드입니다.

Sr. 아니. 방법 및 설명
1

boolean after(Date date)

호출하는 Date 객체에 date로 지정된 날짜보다 이후의 날짜가 포함되어 있으면 true를 반환하고, 그렇지 않으면 false를 반환합니다.

2

boolean before(Date date)

호출하는 Date 객체에 date로 지정된 날짜보다 이전 날짜가 포함되어 있으면 true를 반환하고, 그렇지 않으면 false를 반환합니다.

Object clone( )

호출하는 Date 개체를 복제합니다.

4

int compareTo(Date date)

호출하는 객체의 값을 날짜의 값과 비교합니다. 값이 같으면 0을 반환합니다. 호출하는 객체가 날짜보다 이전이면 음수 값을 반환합니다. 호출하는 객체가 날짜 이후 인 경우 양수 값을 반환합니다.

5

int compareTo(Object obj)

obj가 Date 클래스 인 경우 compareTo (Date)와 동일하게 작동합니다. 그렇지 않으면 ClassCastException이 발생합니다.

6

boolean equals(Object date)

호출하는 Date 객체에 date로 지정된 것과 동일한 시간 및 날짜가 포함되어 있으면 true를 반환하고, 그렇지 않으면 false를 반환합니다.

7

long getTime( )

1970 년 1 월 1 일 이후 경과 한 밀리 초 수를 반환합니다.

8

int hashCode( )

호출하는 객체의 해시 코드를 반환합니다.

9

void setTime(long time)

1970 년 1 월 1 일 자정부터 경과 된 시간 (밀리 초)을 나타내는 시간으로 지정된 시간과 날짜를 설정합니다.

10

String toString( )

호출하는 Date 객체를 문자열로 변환하고 결과를 반환합니다.

현재 날짜 및 시간 가져 오기

이것은 Java에서 현재 날짜와 시간을 얻는 매우 쉬운 방법입니다. toString () 메서드 와 함께 간단한 Date 객체를 사용하여 다음과 같이 현재 날짜와 시간을 인쇄 할 수 있습니다.

import java.util.Date;
public class DateDemo {

   public static void main(String args[]) {
      // Instantiate a Date object
      Date date = new Date();

      // display time and date using toString()
      System.out.println(date.toString());
   }
}

이것은 다음 결과를 생성합니다-

산출

on May 04 09:51:52 CDT 2009

날짜 비교

다음은 두 날짜를 비교하는 세 가지 방법입니다.

  • getTime ()을 사용하여 두 객체에 대해 1970 년 1 월 1 일 자정 이후 경과 한 밀리 초 수를 얻은 다음이 두 값을 비교할 수 있습니다.

  • before (), after () 및 equals () 메서드를 사용할 수 있습니다. 예를 들어, 해당 월의 12 일이 18 일 이전이므로 new Date (99, 2, 12) .before (new Date (99, 2, 18))는 true를 반환합니다.

  • Comparable 인터페이스에 의해 정의되고 Date에 의해 구현되는 compareTo () 메서드를 사용할 수 있습니다.

SimpleDateFormat을 사용한 날짜 형식

SimpleDateFormat은 로케일 구분 방식으로 날짜를 형식화하고 구문 분석하기위한 구체적인 클래스입니다. SimpleDateFormat을 사용하면 날짜-시간 형식화에 대한 사용자 정의 패턴을 선택하여 시작할 수 있습니다.

import java.util.*;
import java.text.*;

public class DateDemo {

   public static void main(String args[]) {
      Date dNow = new Date( );
      SimpleDateFormat ft = 
      new SimpleDateFormat ("E yyyy.MM.dd 'at' hh:mm:ss a zzz");

      System.out.println("Current Date: " + ft.format(dNow));
   }
}

이것은 다음 결과를 생성합니다-

산출

Current Date: Sun 2004.07.18 at 04:14:09 PM PDT

간단한 DateFormat 형식 코드

시간 형식을 지정하려면 시간 패턴 문자열을 사용하십시오. 이 패턴에서 모든 ASCII 문자는 다음과 같이 정의되는 패턴 문자로 예약되어 있습니다.

캐릭터 기술
시대 지정자 기원 후
와이 4 자리 연도 2001 년
미디엄 년의 달 7 월 또는 7 월
월의 일 10
h 오전 / 오후 시간 (1 ~ 12) 12
H 하루 중 시간 (0 ~ 23) 22
미디엄 30
에스 분에 초 55
에스 밀리 초 234
이자형 요일 화요일
연중 하루 360
에프 매월 요일 2 (7 월 둘째 수요일)
w 연중 주 40
W 한 달의 주 1
오전 / 오후 마커 오후
케이 하루 중 시간 (1 ~ 24) 24
케이 오전 / 오후 시간 (0 ~ 11) 10
시간대 동부 표준시
' 텍스트를 보려면 이스케이프 구분자
" 작은 따옴표 `

printf를 사용한 날짜 형식

날짜 및 시간 형식화는 다음을 사용하여 매우 쉽게 수행 할 수 있습니다. printf방법. 다음으로 시작하는 두 글자 형식을 사용합니다.t 다음 코드와 같이 표의 문자 중 하나로 끝납니다.

import java.util.Date;
public class DateDemo {

   public static void main(String args[]) {
      // Instantiate a Date object
      Date date = new Date();

      // display time and date
      String str = String.format("Current Date/Time : %tc", date );

      System.out.printf(str);
   }
}

이것은 다음 결과를 생성합니다-

산출

Current Date/Time : Sat Dec 15 16:37:57 MST 2012

각 부분의 형식을 지정하기 위해 날짜를 여러 번 제공해야한다면 조금 어리석은 일입니다. 따라서 형식 문자열은 형식화 할 인수의 인덱스를 나타낼 수 있습니다.

인덱스는 % 바로 뒤에 와야하며 $로 종료되어야합니다.

import java.util.Date;
public class DateDemo {

   public static void main(String args[]) {
      // Instantiate a Date object
      Date date = new Date();
  
      // display time and date
      System.out.printf("%1$s %2$tB %2$td, %2$tY", "Due date:", date);
   }
}

이것은 다음 결과를 생성합니다-

산출

Due date: February 09, 2004

또는 <플래그를 사용할 수 있습니다. 이전 형식 사양과 동일한 인수를 다시 사용해야 함을 나타냅니다.

import java.util.Date;
public class DateDemo {

   public static void main(String args[]) {
      // Instantiate a Date object
      Date date = new Date();
  
      // display formatted date
      System.out.printf("%s %tB %<te, %<tY", "Due date:", date);
   }
}

이것은 다음 결과를 생성합니다-

산출

Due date: February 09, 2004

날짜 및 시간 변환 문자

캐릭터 기술
완전한 날짜와 시간 Mon May 04 09:51:52 CDT 2009
에프 ISO 8601 날짜 2004-02-09
미국 형식 날짜 (월 / 일 / 년) 2004 년 2 월 9 일
24 시간 18:05:19
아르 자형 12 시간 오후 6:05:19
아르 자형 24 시간 시간, 초 없음 18:05
와이 4 자리 연도 (앞에 0이 있음) 2004 년
와이 연도의 마지막 두 자리 (앞에 0이 있음) 04
연도의 처음 두 자리 (앞에 0이 있음) 20
전체 월 이름 이월
축약 된 월 이름 2 월
미디엄 두 자리 월 (앞에 0이 있음) 02
두 자리 일 (앞에 0이 있음) 03
이자형 두 자리 일 (앞에 0이 없음) 9
평일 전체 이름 월요일
축약 된 요일 이름
제이 연중 세 자리 일 (앞에 0이 있음) 069
H 00에서 23 사이의 두 자리 시간 (앞에 0이 있음) 18
케이 0에서 23 사이의 두 자리 시간 (앞에 0이 없음) 18
나는 01과 12 사이의 두 자리 시간 (앞에 0이 있음) 06
1에서 12 사이의 두 자리 시간 (앞에 0이 없음) 6
미디엄 두 자리 분 (앞에 0이 있음) 05
에스 2 자리 초 (앞에 0이 있음) 19
3 자리 밀리 초 (앞에 0이 있음) 047
9 자리 나노초 (선행 0 포함) 047000000
아침 또는 오후 대문자 표시 오후
아침 또는 오후 소문자 표시 오후
GMT에서 RFC 822 숫자 오프셋 -0800
시간대 PST
에스 1970-01-01 00:00:00 GMT 이후 초 1078884319
1970-01-01 00:00:00 GMT 이후의 밀리 초 1078884319047

날짜 및 시간과 관련된 다른 유용한 클래스가 있습니다. 자세한 내용은 Java Standard 문서를 참조하십시오.

문자열을 날짜로 구문 분석

SimpleDateFormat 클래스에는 주어진 SimpleDateFormat 객체에 저장된 형식에 따라 문자열을 구문 분석하는 parse ()와 같은 몇 가지 추가 메서드가 있습니다.

import java.util.*;
import java.text.*;
  
public class DateDemo {

   public static void main(String args[]) {
      SimpleDateFormat ft = new SimpleDateFormat ("yyyy-MM-dd"); 
      String input = args.length == 0 ? "1818-11-11" : args[0]; 

      System.out.print(input + " Parses as "); 
      Date t;
      try {
         t = ft.parse(input); 
         System.out.println(t); 
      } catch (ParseException e) { 
         System.out.println("Unparseable using " + ft); 
      }
   }
}

위 프로그램의 샘플 실행은 다음 결과를 생성합니다.

산출

1818-11-11 Parses as Wed Nov 11 00:00:00 EST 1818

잠시 자

1 밀리 초부터 컴퓨터 수명까지 원하는 기간 동안 잠자기 가능합니다. 예를 들어, 다음 프로그램은 3 초 동안 휴면합니다.

import java.util.*;
public class SleepDemo {

   public static void main(String args[]) {
      try { 
         System.out.println(new Date( ) + "\n"); 
         Thread.sleep(5*60*10); 
         System.out.println(new Date( ) + "\n"); 
      } catch (Exception e) {
         System.out.println("Got an exception!"); 
      }
   }
}

이것은 다음 결과를 생성합니다-

산출

Sun May 03 18:04:41 GMT 2009
Sun May 03 18:04:51 GMT 2009

경과 시간 측정

때때로 특정 시점을 밀리 초 단위로 측정해야 할 수도 있습니다. 다시 한번 위의 예를 다시 작성해 봅시다.

import java.util.*;
public class DiffDemo {

   public static void main(String args[]) {
      try {
         long start = System.currentTimeMillis( );
         System.out.println(new Date( ) + "\n");
         
         Thread.sleep(5*60*10);
         System.out.println(new Date( ) + "\n");
         
         long end = System.currentTimeMillis( );
         long diff = end - start;
         System.out.println("Difference is : " + diff);
      } catch (Exception e) {
         System.out.println("Got an exception!");
      }
   }
}

이것은 다음 결과를 생성합니다-

산출

Sun May 03 18:16:51 GMT 2009
Sun May 03 18:16:57 GMT 2009
Difference is : 5993

GregorianCalendar 클래스

GregorianCalendar는 익숙한 일반 그레고리력 달력을 구현하는 Calendar 클래스의 구체적인 구현입니다. 이 튜토리얼에서는 Calendar 클래스에 대해 논의하지 않았으며 이에 대한 표준 Java 문서를 찾을 수 있습니다.

그만큼 getInstance( )Calendar 메소드는 기본 로케일 및 시간대의 현재 날짜 및 시간으로 초기화 된 GregorianCalendar를 리턴합니다. GregorianCalendar는 AD와 BC의 두 필드를 정의합니다. 이들은 그레고리력으로 정의 된 두 시대를 나타냅니다.

GregorianCalendar 객체에 대한 여러 생성자가 있습니다.

Sr. 아니. 생성자 및 설명
1

GregorianCalendar()

기본 로케일이있는 기본 시간대의 현재 시간을 사용하여 기본 GregorianCalendar를 구성합니다.

2

GregorianCalendar(int year, int month, int date)

기본 로케일을 사용하는 기본 시간대에 설정된 지정된 날짜로 GregorianCalendar를 구성합니다.

GregorianCalendar(int year, int month, int date, int hour, int minute)

기본 로케일로 기본 시간대에 대해 설정된 지정된 날짜 및 시간으로 GregorianCalendar를 구성합니다.

4

GregorianCalendar(int year, int month, int date, int hour, int minute, int second)

기본 로케일로 기본 시간대에 대해 설정된 지정된 날짜 및 시간으로 GregorianCalendar를 구성합니다.

5

GregorianCalendar(Locale aLocale)

제공된 로케일의 기본 시간대의 현재 시간을 기반으로 GregorianCalendar를 구성합니다.

6

GregorianCalendar(TimeZone zone)

기본 로케일로 지정된 시간대의 현재 시간을 기반으로 GregorianCalendar를 구성합니다.

7

GregorianCalendar(TimeZone zone, Locale aLocale)

제공된 로케일로 제공된 시간대의 현재 시간을 기반으로 GregorianCalendar를 구성합니다.

다음은 GregorianCalendar 클래스에서 제공하는 몇 가지 유용한 지원 방법 목록입니다.

Sr. 아니. 방법 및 설명
1

void add(int field, int amount)

달력의 규칙에 따라 지정된 (서명 된) 시간을 주어진 시간 필드에 추가합니다.

2

protected void computeFields()

UTC를 밀리 초로 시간 필드 값으로 변환합니다.

protected void computeTime()

달력 재정의 시간 필드 값을 밀리 초 단위의 UTC로 변환합니다.

4

boolean equals(Object obj)

이 GregorianCalendar를 오브젝트 참조와 비교합니다.

5

int get(int field)

주어진 시간 필드에 대한 값을 가져옵니다.

6

int getActualMaximum(int field)

현재 날짜에서이 필드가 가질 수있는 최대 값을 반환합니다.

7

int getActualMinimum(int field)

현재 날짜에서이 필드가 가질 수있는 최소값을 반환합니다.

8

int getGreatestMinimum(int field)

다양한 경우 주어진 필드에 대해 가장 높은 최소값을 반환합니다.

9

Date getGregorianChange()

그레고리력 변경 날짜를 가져옵니다.

10

int getLeastMaximum(int field)

다양한 경우 주어진 필드에 대해 가장 낮은 최대 값을 반환합니다.

11

int getMaximum(int field)

주어진 필드의 최대 값을 반환합니다.

12

Date getTime()

이 캘린더의 현재 시간을 가져옵니다.

13

long getTimeInMillis()

이 캘린더의 현재 시간을 길게 가져옵니다.

14

TimeZone getTimeZone()

시간대를 가져옵니다.

15

int getMinimum(int field)

주어진 필드의 최소값을 반환합니다.

16

int hashCode()

hashCode를 재정의합니다.

17

boolean isLeapYear(int year)

주어진 연도가 윤년인지 확인합니다.

18

void roll(int field, boolean up)

더 큰 필드를 변경하지 않고 주어진 시간 필드에서 단일 시간 단위를 더하거나 뺍니다 (위 / 아래).

19

void set(int field, int value)

주어진 값으로 시간 필드를 설정합니다.

20

void set(int year, int month, int date)

년, 월 및 날짜 필드의 값을 설정합니다.

21

void set(int year, int month, int date, int hour, int minute)

년, 월, 일,시 및 분 필드의 값을 설정합니다.

22

void set(int year, int month, int date, int hour, int minute, int second)

년, 월, 일,시, 분 및 초 필드의 값을 설정합니다.

23

void setGregorianChange(Date date)

GregorianCalendar 변경 날짜를 설정합니다.

24

void setTime(Date date)

주어진 날짜로이 달력의 현재 시간을 설정합니다.

25

void setTimeInMillis(long millis)

주어진 long 값에서이 달력의 현재 시간을 설정합니다.

26

void setTimeZone(TimeZone value)

주어진 시간대 값으로 시간대를 설정합니다.

27

String toString()

이 달력의 문자열 표현을 반환합니다.

import java.util.*;
public class GregorianCalendarDemo {

   public static void main(String args[]) {
      String months[] = {"Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", 
         "Oct", "Nov", "Dec"};
      
      int year;
      // Create a Gregorian calendar initialized
      // with the current date and time in the
      // default locale and timezone.
      
      GregorianCalendar gcalendar = new GregorianCalendar();
      
      // Display current time and date information.
      System.out.print("Date: ");
      System.out.print(months[gcalendar.get(Calendar.MONTH)]);
      System.out.print(" " + gcalendar.get(Calendar.DATE) + " ");
      System.out.println(year = gcalendar.get(Calendar.YEAR));
      System.out.print("Time: ");
      System.out.print(gcalendar.get(Calendar.HOUR) + ":");
      System.out.print(gcalendar.get(Calendar.MINUTE) + ":");
      System.out.println(gcalendar.get(Calendar.SECOND));

      // Test if the current year is a leap year
      if(gcalendar.isLeapYear(year)) {
         System.out.println("The current year is a leap year");
      }else {
         System.out.println("The current year is not a leap year");
      }
   }
}

이것은 다음 결과를 생성합니다-

산출

Date: Apr 22 2009
Time: 11:25:27
The current year is not a leap year

Calendar 클래스에서 사용 가능한 전체 상수 목록은 표준 Java 문서를 참조하십시오.

Java는 정규식과 패턴 일치를 위해 java.util.regex 패키지를 제공합니다. Java 정규식은 Perl 프로그래밍 언어와 매우 유사하며 배우기 매우 쉽습니다.

정규식은 패턴에 포함 된 특수 구문을 사용하여 다른 문자열 또는 문자열 집합을 일치 시키거나 찾는 데 도움이되는 특수 문자 시퀀스입니다. 텍스트와 데이터를 검색, 편집 또는 조작하는 데 사용할 수 있습니다.

java.util.regex 패키지는 주로 다음 세 가지 클래스로 구성됩니다.

  • Pattern Class− Pattern 객체는 정규 표현식의 컴파일 된 표현입니다. Pattern 클래스는 공용 생성자를 제공하지 않습니다. 패턴을 생성하려면 먼저 공개 정적 중 하나를 호출해야합니다.compile()그런 다음 Pattern 객체를 반환합니다. 이러한 메서드는 정규식을 첫 번째 인수로 받아들입니다.

  • Matcher Class− Matcher 객체는 패턴을 해석하고 입력 문자열에 대해 일치 작업을 수행하는 엔진입니다. Pattern 클래스와 마찬가지로 Matcher는 공용 생성자를 정의하지 않습니다. Matcher 개체는matcher() Pattern 객체의 메서드.

  • PatternSyntaxException − PatternSyntaxException 객체는 정규 표현식 패턴에서 구문 오류를 나타내는 확인되지 않은 예외입니다.

그룹 캡처

그룹 캡처는 여러 문자를 단일 단위로 처리하는 방법입니다. 그룹화 할 문자를 괄호 안에 배치하여 생성됩니다. 예를 들어 정규식 (개)은 문자 "d", "o"및 "g"를 포함하는 단일 그룹을 만듭니다.

캡처 그룹은 왼쪽에서 오른쪽으로 여는 괄호를 세어 번호가 매겨집니다. 예를 들어 ((A) (B (C))) 식에는 4 개의 그룹이 있습니다.

  • ((A)(B(C)))
  • (A)
  • (B(C))
  • (C)

식에 몇 개의 그룹이 있는지 확인하려면 matcher 개체에서 groupCount 메서드를 호출합니다. groupCount 메서드는int matcher의 패턴에있는 캡처 그룹의 수를 보여줍니다.

항상 전체 표현식을 나타내는 특수 그룹 인 그룹 0도 있습니다. 이 그룹은 groupCount에서보고 한 총계에 포함되지 않습니다.

Example

다음 예제는 주어진 영숫자 문자열에서 숫자 문자열을 찾는 방법을 보여줍니다-

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class RegexMatches {

   public static void main( String args[] ) {
      // String to be scanned to find the pattern.
      String line = "This order was placed for QT3000! OK?";
      String pattern = "(.*)(\\d+)(.*)";

      // Create a Pattern object
      Pattern r = Pattern.compile(pattern);

      // Now create matcher object.
      Matcher m = r.matcher(line);
      if (m.find( )) {
         System.out.println("Found value: " + m.group(0) );
         System.out.println("Found value: " + m.group(1) );
         System.out.println("Found value: " + m.group(2) );
      }else {
         System.out.println("NO MATCH");
      }
   }
}

이것은 다음 결과를 생성합니다-

Output

Found value: This order was placed for QT3000! OK?
Found value: This order was placed for QT300
Found value: 0

정규식 구문

다음은 Java에서 사용할 수있는 모든 정규식 메타 문자 구문을 나열한 표입니다.

하위 표현 성냥
^ 줄의 시작과 일치합니다.
$ 줄의 끝과 일치합니다.
. 개행을 제외한 모든 단일 문자와 일치합니다. 사용m 옵션을 사용하면 개행 문자도 일치시킬 수 있습니다.
[...] 괄호 안의 모든 단일 문자와 일치합니다.
[^ ...] 대괄호가 아닌 단일 문자와 일치합니다.
\ㅏ 전체 문자열의 시작.
\지 전체 문자열의 끝입니다.
\지 허용되는 마지막 줄 종결자를 제외한 전체 문자열의 끝입니다.
레* 0 개 이상의 이전 표현식과 일치합니다.
re + 이전 항목 중 하나 이상과 일치합니다.
레? 0 개 또는 1 개의 이전 표현식과 일치합니다.
re {n} 정확히 n 개의 이전 표현식과 일치합니다.
re {n,} n 개 이상의 이전 표현식과 일치합니다.
re {n, m} 이전 표현식의 최소 n 개 및 최대 m 개 항목과 일치합니다.
a | 비 a 또는 b와 일치합니다.
(레) 정규식을 그룹화하고 일치하는 텍스트를 기억합니다.
(? : 다시) 일치하는 텍스트를 기억하지 않고 정규식을 그룹화합니다.
(?> 다시) 역 추적없이 독립적 인 패턴과 일치합니다.
\ w 단어 문자와 일치합니다.
\ W 단어가 아닌 문자와 일치합니다.
\에스 공백과 일치합니다. [\ t \ n \ r \ f]와 같습니다.
\에스 비공 백과 일치합니다.
\디 숫자와 일치합니다. [0-9]와 같습니다.
\디 숫자가 아닌 것과 일치합니다.
\ㅏ 문자열의 시작과 일치합니다.
\지 문자열의 끝과 일치합니다. 개행이 존재하면 개행 바로 전에 일치합니다.
\지 문자열의 끝과 일치합니다.
\지 마지막 경기가 끝난 지점과 일치합니다.
\엔 캡처 그룹 번호 "n"에 대한 역 참조.
\비 대괄호 밖에있을 때 단어 경계와 일치합니다. 대괄호 안에있을 때 백 스페이스 (0x08)와 일치합니다.
\비 비 단어 경계와 일치합니다.
\ n, \ t 등 줄 바꿈, 캐리지 리턴, 탭 등과 일치합니다.
\큐 \ E까지 모든 문자를 이스케이프 (따옴표)하십시오.
\이자형 \ Q로 시작하는 인용을 끝냅니다.

Matcher 클래스의 방법

다음은 유용한 인스턴스 메소드 목록입니다.

색인 방법

인덱스 메서드는 입력 문자열에서 일치가 발견 된 위치를 정확하게 보여주는 유용한 인덱스 값을 제공합니다.

Sr. 아니. 방법 및 설명
1

public int start()

이전 일치의 시작 인덱스를 반환합니다.

2

public int start(int group)

이전 일치 작업 중에 지정된 그룹이 캡처 한 하위 시퀀스의 시작 인덱스를 반환합니다.

public int end()

일치하는 마지막 문자 이후의 오프셋을 반환합니다.

4

public int end(int group)

이전 일치 작업 중에 지정된 그룹이 캡처 한 하위 시퀀스의 마지막 문자 뒤의 오프셋을 반환합니다.

연구 방법

연구 방법은 입력 문자열을 검토하고 패턴이 있는지 여부를 나타내는 부울을 반환합니다.

Sr. 아니. 방법 및 설명
1

public boolean lookingAt()

영역의 시작에서 시작하여 패턴에 대해 입력 시퀀스를 일치 시키려고 시도합니다.

2

public boolean find()

패턴과 일치하는 입력 시퀀스의 다음 하위 시퀀스를 찾으려고합니다.

public boolean find(int start)

이 매처를 재설정 한 다음 지정된 인덱스에서 시작하여 패턴과 일치하는 입력 시퀀스의 다음 하위 시퀀스를 찾으려고합니다.

4

public boolean matches()

패턴에 대해 전체 영역을 일치 시키려고 시도합니다.

교체 방법

대체 방법은 입력 문자열에서 텍스트를 대체하는 데 유용한 방법입니다.

Sr. 아니. 방법 및 설명
1

public Matcher appendReplacement(StringBuffer sb, String replacement)

비 터미널 추가 및 바꾸기 단계를 구현합니다.

2

public StringBuffer appendTail(StringBuffer sb)

터미널 추가 및 바꾸기 단계를 구현합니다.

public String replaceAll(String replacement)

패턴과 일치하는 입력 시퀀스의 모든 하위 시퀀스를 지정된 대체 문자열로 바꿉니다.

4

public String replaceFirst(String replacement)

패턴과 일치하는 입력 시퀀스의 첫 번째 하위 시퀀스를 지정된 대체 문자열로 바꿉니다.

5

public static String quoteReplacement(String s)

지정된 문자열에 대한 리터럴 대체 문자열을 반환합니다. 이 메서드는 리터럴 대체로 작동하는 문자열을 생성합니다.s Matcher 클래스의 appendReplacement 메서드에서.

시작 및 종료 방법

다음은 입력 문자열에 "cat"이라는 단어가 나타나는 횟수를 세는 예입니다.

Example

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class RegexMatches {

   private static final String REGEX = "\\bcat\\b";
   private static final String INPUT = "cat cat cat cattie cat";

   public static void main( String args[] ) {
      Pattern p = Pattern.compile(REGEX);
      Matcher m = p.matcher(INPUT);   // get a matcher object
      int count = 0;

      while(m.find()) {
         count++;
         System.out.println("Match number "+count);
         System.out.println("start(): "+m.start());
         System.out.println("end(): "+m.end());
      }
   }
}

이것은 다음 결과를 생성합니다-

Output

Match number 1
start(): 0
end(): 3
Match number 2
start(): 4
end(): 7
Match number 3
start(): 8
end(): 11
Match number 4
start(): 19
end(): 22

이 예제에서는 단어 경계를 사용하여 문자 "c" "a" "t"가 단순히 긴 단어의 하위 문자열이 아님을 확인할 수 있습니다. 또한 입력 문자열에서 일치가 발생한 위치에 대한 유용한 정보를 제공합니다.

start 메서드는 이전 일치 작업 중에 지정된 그룹에 의해 캡처 된 하위 시퀀스의 시작 인덱스를 반환하고 끝은 일치 된 마지막 문자의 인덱스에 1을 더한 값을 반환합니다.

경기 및보고 방법

match 및 lookingAt 메서드는 모두 패턴에 대해 입력 시퀀스를 일치 시키려고합니다. 그러나 차이점은 일치를 위해서는 전체 입력 시퀀스가 ​​일치해야하지만 lookingAt은 일치하지 않는다는 것입니다.

두 방법 모두 항상 입력 문자열의 시작 부분에서 시작합니다. 다음은 기능을 설명하는 예입니다.

Example

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class RegexMatches {

   private static final String REGEX = "foo";
   private static final String INPUT = "fooooooooooooooooo";
   private static Pattern pattern;
   private static Matcher matcher;

   public static void main( String args[] ) {
      pattern = Pattern.compile(REGEX);
      matcher = pattern.matcher(INPUT);

      System.out.println("Current REGEX is: "+REGEX);
      System.out.println("Current INPUT is: "+INPUT);

      System.out.println("lookingAt(): "+matcher.lookingAt());
      System.out.println("matches(): "+matcher.matches());
   }
}

이것은 다음 결과를 생성합니다-

Output

Current REGEX is: foo
Current INPUT is: fooooooooooooooooo
lookingAt(): true
matches(): false

replaceFirst 및 replaceAll 메서드

replaceFirst 및 replaceAll 메서드는 지정된 정규식과 일치하는 텍스트를 바꿉니다. 이름에서 알 수 있듯이 replaceFirst는 첫 번째 항목을 대체하고 replaceAll은 모든 항목을 대체합니다.

다음은 기능을 설명하는 예입니다.

Example

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class RegexMatches {

   private static String REGEX = "dog";
   private static String INPUT = "The dog says meow. " + "All dogs say meow.";
   private static String REPLACE = "cat";

   public static void main(String[] args) {
      Pattern p = Pattern.compile(REGEX);
      
      // get a matcher object
      Matcher m = p.matcher(INPUT); 
      INPUT = m.replaceAll(REPLACE);
      System.out.println(INPUT);
   }
}

이것은 다음 결과를 생성합니다-

Output

The cat says meow. All cats say meow.

appendReplacement 및 appendTail 메서드

Matcher 클래스는 텍스트 교체를위한 appendReplacement 및 appendTail 메서드도 제공합니다.

다음은 기능을 설명하는 예입니다.

Example

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class RegexMatches {

   private static String REGEX = "a*b";
   private static String INPUT = "aabfooaabfooabfoob";
   private static String REPLACE = "-";
   public static void main(String[] args) {

      Pattern p = Pattern.compile(REGEX);
      
      // get a matcher object
      Matcher m = p.matcher(INPUT);
      StringBuffer sb = new StringBuffer();
      while(m.find()) {
         m.appendReplacement(sb, REPLACE);
      }
      m.appendTail(sb);
      System.out.println(sb.toString());
   }
}

이것은 다음 결과를 생성합니다-

Output

-foo-foo-foo-

PatternSyntaxException 클래스 메서드

PatternSyntaxException은 정규식 패턴의 구문 오류를 나타내는 확인되지 않은 예외입니다. PatternSyntaxException 클래스는 무엇이 잘못되었는지 확인하는 데 도움이되는 다음 메서드를 제공합니다.

Sr. 아니. 방법 및 설명
1

public String getDescription()

오류에 대한 설명을 검색합니다.

2

public int getIndex()

오류 색인을 검색합니다.

public String getPattern()

잘못된 정규식 패턴을 검색합니다.

4

public String getMessage()

구문 오류에 대한 설명과 해당 색인, 잘못된 정규식 패턴, 패턴 내 오류 색인의 시각적 표시가 포함 된 여러 줄 문자열을 반환합니다.

Java 메소드는 작업을 수행하기 위해 함께 그룹화되는 명령문 모음입니다. System.out을 호출 할 때.println() 예를 들어, 시스템은 콘솔에 메시지를 표시하기 위해 실제로 여러 명령문을 실행합니다.

이제 반환 값을 사용하거나 사용하지 않고 자신 만의 메서드를 만들고, 매개 변수를 사용하거나 사용하지 않고 메서드를 호출하고, 프로그램 디자인에서 메서드 추상화를 적용하는 방법을 배웁니다.

생성 방법

메소드의 구문을 설명하기 위해 다음 예제를 고려하십시오.

Syntax

public static int methodName(int a, int b) {
   // body
}

여기,

  • public static − 수정 자

  • int − 반환 유형

  • methodName − 방법의 이름

  • a, b − 형식 매개 변수

  • int a, int b − 매개 변수 목록

메서드 정의는 메서드 헤더와 메서드 본문으로 구성됩니다. 다음 구문에서 동일하게 표시됩니다.

Syntax

modifier returnType nameOfMethod (Parameter List) {
   // method body
}

위에 표시된 구문에는 다음이 포함됩니다.

  • modifier − 방법의 접근 유형을 정의하며 사용 여부는 선택 사항입니다.

  • returnType − 메서드는 값을 반환 할 수 있습니다.

  • nameOfMethod− 이것은 분석법 이름입니다. 메소드 서명은 메소드 이름과 매개 변수 목록으로 구성됩니다.

  • Parameter List− 매개 변수 목록, 방법의 매개 변수 유형, 순서 및 개수입니다. 이는 선택 사항이며 메서드에는 매개 변수가 없을 수 있습니다.

  • method body − 메서드 본문은 메서드가 명령문으로 수행하는 작업을 정의합니다.

Example

다음은 위에 정의 된 메서드의 소스 코드입니다. min(). 이 메서드는 두 개의 매개 변수 num1과 num2를 취하고 둘 사이의 최대 값을 반환합니다.

/** the snippet returns the minimum between two numbers */

public static int minFunction(int n1, int n2) {
   int min;
   if (n1 > n2)
      min = n2;
   else
      min = n1;

   return min; 
}

메서드 호출

메서드를 사용하려면 호출해야합니다. 메서드가 호출되는 방법에는 두 가지가 있습니다. 즉, 메서드는 값을 반환하거나 아무것도 반환하지 않습니다 (반환 값 없음).

메서드 호출 프로세스는 간단합니다. 프로그램이 메소드를 호출하면 프로그램 제어가 호출 된 메소드로 전송됩니다. 이 호출 된 메서드는 다음 두 가지 조건에서 호출자에게 제어를 반환합니다.

  • return 문이 실행됩니다.
  • 닫는 중괄호를 종료하는 메서드에 도달합니다.

void를 반환하는 메서드는 문에 대한 호출로 간주됩니다. 예를 들어 보겠습니다-

System.out.println("This is tutorialspoint.com!");

값을 반환하는 방법은 다음 예에서 이해할 수 있습니다.

int result = sum(6, 9);

다음은 메서드를 정의하는 방법과 호출하는 방법을 보여주는 예제입니다.

Example

public class ExampleMinNumber {
   
   public static void main(String[] args) {
      int a = 11;
      int b = 6;
      int c = minFunction(a, b);
      System.out.println("Minimum Value = " + c);
   }

   /** returns the minimum of two numbers */
   public static int minFunction(int n1, int n2) {
      int min;
      if (n1 > n2)
         min = n2;
      else
         min = n1;

      return min; 
   }
}

이것은 다음 결과를 생성합니다-

Output

Minimum value = 6

void 키워드

void 키워드를 사용하면 값을 반환하지 않는 메서드를 만들 수 있습니다. 다음 예제에서는 void 메서드 methodRankPoints를 고려하고 있습니다. 이 메서드는 값을 반환하지 않는 void 메서드입니다. void 메서드에 대한 호출은 문이어야합니다. 즉, methodRankPoints (255.7); . 다음 예제와 같이 세미콜론으로 끝나는 Java 문입니다.

Example

public class ExampleVoid {

   public static void main(String[] args) {
      methodRankPoints(255.7);
   }

   public static void methodRankPoints(double points) {
      if (points >= 202.5) {
         System.out.println("Rank:A1");
      }else if (points >= 122.4) {
         System.out.println("Rank:A2");
      }else {
         System.out.println("Rank:A3");
      }
   }
}

이것은 다음 결과를 생성합니다-

Output

Rank:A1

값으로 매개 변수 전달

호출 프로세스에서 작업하는 동안 인수가 전달됩니다. 메서드 사양의 각 매개 변수와 동일한 순서 여야합니다. 매개 변수는 값 또는 참조로 전달할 수 있습니다.

매개 변수를 값으로 전달한다는 것은 매개 변수가있는 메소드를 호출하는 것을 의미합니다. 이를 통해 인수 값이 매개 변수로 전달됩니다.

Example

다음 프로그램은 매개 변수를 값으로 전달하는 예를 보여줍니다. 인수 값은 메서드 호출 후에도 동일하게 유지됩니다.

public class swappingExample {

   public static void main(String[] args) {
      int a = 30;
      int b = 45;
      System.out.println("Before swapping, a = " + a + " and b = " + b);

      // Invoke the swap method
      swapFunction(a, b);
      System.out.println("\n**Now, Before and After swapping values will be same here**:");
      System.out.println("After swapping, a = " + a + " and b is " + b);
   }

   public static void swapFunction(int a, int b) {
      System.out.println("Before swapping(Inside), a = " + a + " b = " + b);
      
      // Swap n1 with n2
      int c = a;
      a = b;
      b = c;
      System.out.println("After swapping(Inside), a = " + a + " b = " + b);
   }
}

이것은 다음 결과를 생성합니다-

Output

Before swapping, a = 30 and b = 45
Before swapping(Inside), a = 30 b = 45
After swapping(Inside), a = 45 b = 30

**Now, Before and After swapping values will be same here**:
After swapping, a = 30 and b is 45

메서드 오버로딩

클래스에 이름은 같지만 매개 변수가 다른 두 개 이상의 메서드가있는 경우이를 메서드 오버로딩이라고합니다. 재정의와 다릅니다. 재정의에서 메서드는 동일한 메서드 이름, 유형, 매개 변수 수 등을 갖습니다.

정수 유형의 최소 수를 찾기 위해 앞에서 설명한 예를 고려해 보겠습니다. 이중 유형의 최소 수를 찾고 싶다고 가정 해 보겠습니다. 그런 다음 오버로딩 개념을 도입하여 이름은 같지만 매개 변수가 다른 두 개 이상의 메서드를 만듭니다.

다음 예제는 동일하게 설명합니다-

Example

public class ExampleOverloading {

   public static void main(String[] args) {
      int a = 11;
      int b = 6;
      double c = 7.3;
      double d = 9.4;
      int result1 = minFunction(a, b);
      
      // same function name with different parameters
      double result2 = minFunction(c, d);
      System.out.println("Minimum Value = " + result1);
      System.out.println("Minimum Value = " + result2);
   }

   // for integer
   public static int minFunction(int n1, int n2) {
      int min;
      if (n1 > n2)
         min = n2;
      else
         min = n1;

      return min; 
   }
   
   // for double
   public static double minFunction(double n1, double n2) {
     double min;
      if (n1 > n2)
         min = n2;
      else
         min = n1;

      return min; 
   }
}

이것은 다음 결과를 생성합니다-

Output

Minimum Value = 6
Minimum Value = 7.3

메서드를 오버로딩하면 프로그램을 읽을 수 있습니다. 여기서 두 가지 방법은 이름은 같지만 매개 변수는 다릅니다. 정수 및 이중 유형의 최소 숫자가 결과입니다.

명령 줄 인수 사용

때로는 프로그램을 실행할 때 일부 정보를 프로그램에 전달하고 싶을 것입니다. 이는 main ()에 명령 줄 인수를 전달하여 수행됩니다.

명령 줄 인수는 실행될 때 명령 줄에서 프로그램 이름 바로 뒤에 오는 정보입니다. Java 프로그램 내에서 명령 줄 인수에 액세스하는 것은 매우 쉽습니다. 이들은 main ()에 전달 된 String 배열에 문자열로 저장됩니다.

Example

다음 프로그램은 호출되는 모든 명령 줄 인수를 표시합니다.

public class CommandLine {

   public static void main(String args[]) { 
      for(int i = 0; i<args.length; i++) {
         System.out.println("args[" + i + "]: " +  args[i]);
      }
   }
}

여기에 표시된대로이 프로그램을 실행 해보십시오.

$java CommandLine this is a command line 200 -100

이것은 다음 결과를 생성합니다-

Output

args[0]: this
args[1]: is
args[2]: a
args[3]: command
args[4]: line
args[5]: 200
args[6]: -100

this 키워드

this인스턴스 메소드 또는 생성자와 함께 현재 클래스의 객체에 대한 참조로 사용되는 Java의 키워드입니다. 사용 당신이 그런 생성자, 변수와 메소드 같은 클래스의 멤버를 참조 할 수 있습니다.

Notethis 키워드 는 인스턴스 메서드 또는 생성자 내에서만 사용됩니다.

일반적으로 this 는 다음에 사용되는 키워드 입니다.

  • 생성자 또는 메서드 내에서 이름이 같은 경우 인스턴스 변수를 지역 변수와 구별합니다.

class Student {
   int age;   
   Student(int age) {
      this.age = age;	
   }
}
  • 클래스의 다른 생성자에서 한 유형의 생성자 (매개 변수화 된 생성자 또는 기본값)를 호출합니다. 이를 명시 적 생성자 호출이라고합니다.

class Student {
   int age
   Student() {
      this(20);
   }
   
   Student(int age) {
      this.age = age;	
   }
}

Example

다음은 키워드를 사용 하여 클래스 멤버에 액세스 하는 예입니다 . 다음 프로그램을 이름이있는 파일에 복사하여 붙여 넣으십시오.This_Example.java.

public class This_Example {
   // Instance variable num
   int num = 10;
	
   This_Example() {
      System.out.println("This is an example program on keyword this");	
   }

   This_Example(int num) {
      // Invoking the default constructor
      this();
      
      // Assigning the local variable num to the instance variable num
      this.num = num;	   
   }
   
   public void greet() {
      System.out.println("Hi Welcome to Tutorialspoint");
   }
      
   public void print() {
      // Local variable num
      int num = 20;
      
      // Printing the local variable
      System.out.println("value of local variable num is : "+num);
      
      // Printing the instance variable
      System.out.println("value of instance variable num is : "+this.num);
      
      // Invoking the greet method of a class
      this.greet();     
   }
   
   public static void main(String[] args) {
      // Instantiating the class
      This_Example obj1 = new This_Example();
      
      // Invoking the print method
      obj1.print();
	  
      // Passing a new value to the num variable through Parameterized constructor
      This_Example obj2 = new This_Example(30);
      
      // Invoking the print method again
      obj2.print(); 
   }
}

이것은 다음 결과를 생성합니다-

Output

This is an example program on keyword this 
value of local variable num is : 20
value of instance variable num is : 10
Hi Welcome to Tutorialspoint
This is an example program on keyword this 
value of local variable num is : 20
value of instance variable num is : 30
Hi Welcome to Tutorialspoint

변수 인수 (var-args)

JDK 1.5를 사용하면 동일한 유형의 가변 개수의 인수를 메서드에 전달할 수 있습니다. 메소드의 매개 변수는 다음과 같이 선언됩니다.

typeName... parameterName

메소드 선언에서 유형 뒤에 생략 부호 (...)를 지정합니다. 하나의 가변 길이 매개 변수 만 메소드에 지정할 수 있으며이 매개 변수는 마지막 매개 변수 여야합니다. 모든 일반 매개 변수가 앞에 와야합니다.

Example

public class VarargsDemo {

   public static void main(String args[]) {
      // Call method with variable args  
	   printMax(34, 3, 3, 2, 56.5);
      printMax(new double[]{1, 2, 3});
   }

   public static void printMax( double... numbers) {
      if (numbers.length == 0) {
         System.out.println("No argument passed");
         return;
      }

      double result = numbers[0];

      for (int i = 1; i <  numbers.length; i++)
      if (numbers[i] >  result)
      result = numbers[i];
      System.out.println("The max value is " + result);
   }
}

이것은 다음 결과를 생성합니다-

Output

The max value is 56.5
The max value is 3.0

finalize () 메서드

가비지 컬렉터에 의한 객체의 최종 소멸 직전에 호출 될 메서드를 정의 할 수 있습니다. 이 메서드는finalize( ), 객체가 깨끗하게 종료되도록하는 데 사용할 수 있습니다.

예를 들어 finalize ()를 사용하여 해당 객체가 소유 한 열린 파일이 닫혔는지 확인할 수 있습니다.

클래스에 종료자를 추가하려면 간단히 finalize () 메서드를 정의하면됩니다. Java 런타임은 해당 클래스의 객체를 재활용하려고 할 때마다 해당 메서드를 호출합니다.

finalize () 메서드 내에서 객체가 소멸되기 전에 수행해야하는 작업을 지정합니다.

finalize () 메서드는 다음과 같은 일반적인 형식을 갖습니다.

protected void finalize( ) {
   // finalization code here
}

여기서 protected 키워드는 클래스 외부에 정의 된 코드에 의해 finalize ()에 대한 액세스를 방지하는 지정자입니다.

이것은 finalize ()가 언제 실행 될지 알 수 없음을 의미합니다. 예를 들어 가비지 콜렉션이 발생하기 전에 프로그램이 종료되면 finalize ()가 실행되지 않습니다.

java.io 패키지에는 Java에서 입력 및 출력 (I / O)을 수행하는 데 필요한 거의 모든 클래스가 포함되어 있습니다. 이러한 모든 스트림은 입력 소스와 출력 대상을 나타냅니다. java.io 패키지의 스트림은 프리미티브, 객체, 현지화 된 문자 등과 같은 많은 데이터를 지원합니다.

흐름

스트림은 데이터 시퀀스로 정의 할 수 있습니다. 두 종류의 스트림이 있습니다-

  • InPutStream − InputStream은 소스에서 데이터를 읽는 데 사용됩니다.

  • OutPutStream − OutputStream은 대상에 데이터를 쓰는 데 사용됩니다.

Java는 파일 및 네트워크와 관련된 I / O에 대해 강력하지만 유연한 지원을 제공하지만이 자습서에서는 스트림 및 I / O와 관련된 매우 기본적인 기능을 다룹니다. 가장 일반적으로 사용되는 예제를 하나씩 살펴 보겠습니다.

바이트 스트림

Java 바이트 스트림은 8 비트 바이트의 입력 및 출력을 수행하는 데 사용됩니다. 바이트 스트림과 관련된 많은 클래스가 있지만 가장 자주 사용되는 클래스는 다음과 같습니다.FileInputStreamFileOutputStream. 다음은이 두 클래스를 사용하여 입력 파일을 출력 파일로 복사하는 예입니다.

Example

import java.io.*;
public class CopyFile {

   public static void main(String args[]) throws IOException {  
      FileInputStream in = null;
      FileOutputStream out = null;

      try {
         in = new FileInputStream("input.txt");
         out = new FileOutputStream("output.txt");
         
         int c;
         while ((c = in.read()) != -1) {
            out.write(c);
         }
      }finally {
         if (in != null) {
            in.close();
         }
         if (out != null) {
            out.close();
         }
      }
   }
}

이제 파일을 갖자 input.txt 다음 내용으로-

This is test for copy file.

다음 단계로 위의 프로그램을 컴파일하고 실행하면 input.txt에서와 동일한 내용으로 output.txt 파일이 생성됩니다. 따라서 위의 코드를 CopyFile.java 파일에 넣고 다음을 수행합니다.

$javac CopyFile.java $java CopyFile

캐릭터 스트림

자바 Byte 스트림은 8 비트 바이트의 입력 및 출력을 수행하는 데 사용되는 반면 Java Character스트림은 16 비트 유니 코드에 대한 입력 및 출력을 수행하는 데 사용됩니다. 캐릭터 스트림과 관련된 많은 클래스가 있지만 가장 많이 사용되는 클래스는 다음과 같습니다.FileReaderFileWriter. 내부적으로 FileReader는 FileInputStream을 사용하고 FileWriter는 FileOutputStream을 사용하지만 여기서 가장 큰 차이점은 FileReader는 한 번에 2 바이트를 읽고 FileWriter는 한 번에 2 바이트를 쓴다는 것입니다.

위의 예를 다시 작성할 수 있습니다.이 두 클래스를 사용하여 입력 파일 (유니 코드 문자 포함)을 출력 파일에 복사합니다.

Example

import java.io.*;
public class CopyFile {

   public static void main(String args[]) throws IOException {
      FileReader in = null;
      FileWriter out = null;

      try {
         in = new FileReader("input.txt");
         out = new FileWriter("output.txt");
         
         int c;
         while ((c = in.read()) != -1) {
            out.write(c);
         }
      }finally {
         if (in != null) {
            in.close();
         }
         if (out != null) {
            out.close();
         }
      }
   }
}

이제 파일을 갖자 input.txt 다음 내용으로-

This is test for copy file.

다음 단계로 위의 프로그램을 컴파일하고 실행하면 input.txt에서와 동일한 내용으로 output.txt 파일이 생성됩니다. 따라서 위의 코드를 CopyFile.java 파일에 넣고 다음을 수행합니다.

$javac CopyFile.java $java CopyFile

표준 스트림

모든 프로그래밍 언어는 사용자의 프로그램이 키보드에서 입력을받은 다음 컴퓨터 화면에 출력을 생성 할 수있는 표준 I / O를 지원합니다. C 또는 C ++ 프로그래밍 언어를 알고있는 경우 세 가지 표준 장치 STDIN, STDOUT 및 STDERR을 알고 있어야합니다. 마찬가지로 Java는 다음 세 가지 표준 스트림을 제공합니다.

  • Standard Input − 이것은 사용자의 프로그램에 데이터를 공급하는 데 사용되며 일반적으로 키보드는 표준 입력 스트림으로 사용되며 다음과 같이 표시됩니다. System.in.

  • Standard Output − 이것은 사용자의 프로그램에 의해 생성 된 데이터를 출력하는 데 사용되며 일반적으로 컴퓨터 화면은 표준 출력 스트림에 사용되며 다음과 같이 표시됩니다. System.out.

  • Standard Error − 사용자 프로그램에서 생성 된 오류 데이터를 출력하는 데 사용되며 일반적으로 컴퓨터 화면은 표준 오류 스트림에 사용되며 다음과 같이 표시됩니다. System.err.

다음은 간단한 프로그램입니다. InputStreamReader 사용자가 "q"를 입력 할 때까지 표준 입력 스트림을 읽으려면-

Example

import java.io.*;
public class ReadConsole {

   public static void main(String args[]) throws IOException {
      InputStreamReader cin = null;

      try {
         cin = new InputStreamReader(System.in);
         System.out.println("Enter characters, 'q' to quit.");
         char c;
         do {
            c = (char) cin.read();
            System.out.print(c);
         } while(c != 'q');
      }finally {
         if (cin != null) {
            cin.close();
         }
      }
   }
}

위의 코드를 ReadConsole.java 파일에 보관하고 다음 프로그램과 같이 컴파일하고 실행 해 봅시다. 이 프로그램은 'q'를 누를 때까지 동일한 문자를 계속 읽고 출력합니다.

$javac ReadConsole.java $java ReadConsole
Enter characters, 'q' to quit.
1
1
e
e
q
q

파일 읽기 및 쓰기

앞에서 설명한 것처럼 스트림은 데이터 시퀀스로 정의 할 수 있습니다. 그만큼InputStream 소스에서 데이터를 읽는 데 사용되며 OutputStream 대상에 데이터를 쓰는 데 사용됩니다.

다음은 입력 및 출력 스트림을 처리하는 클래스 계층 구조입니다.

두 가지 중요한 흐름은 FileInputStreamFileOutputStream이 자습서에서 설명합니다.

FileInputStream

이 스트림은 파일에서 데이터를 읽는 데 사용됩니다. 키워드를 사용하여 개체를 만들 수 있습니다.new 사용 가능한 여러 유형의 생성자가 있습니다.

다음 생성자는 파일을 읽을 입력 스트림 객체를 생성하기 위해 파일 이름을 문자열로 취합니다.

InputStream f = new FileInputStream("C:/java/hello");

다음 생성자는 파일 개체를 사용하여 파일을 읽을 입력 스트림 개체를 만듭니다. 먼저 다음과 같이 File () 메서드를 사용하여 파일 객체를 만듭니다.

File f = new File("C:/java/hello");
InputStream f = new FileInputStream(f);

일단 당신 의 InputStream의 손에 오브젝트를, 다음 스트리밍 또는 스트림에 다른 작업을 수행 할 읽을 수 있습니다 헬퍼 메소드의 목록이 있습니다.

Sr. 아니. 방법 및 설명
1

public void close() throws IOException{}

이 메서드는 파일 출력 스트림을 닫습니다. 파일과 관련된 모든 시스템 리소스를 해제합니다. IOException이 발생합니다.

2

protected void finalize()throws IOException {}

이 방법은 파일에 대한 연결을 정리합니다. 이 스트림에 대한 참조가 더 이상 없을 때이 파일 출력 스트림의 close 메소드가 호출되는지 확인합니다. IOException이 발생합니다.

public int read(int r)throws IOException{}

이 메서드는 InputStream에서 지정된 데이터 바이트를 읽습니다. int를 반환합니다. 데이터의 다음 바이트를 반환하고 파일의 끝이면 -1이 반환됩니다.

4

public int read(byte[] r) throws IOException{}

이 메소드는 입력 스트림에서 배열로 r.length 바이트를 읽습니다. 읽은 총 바이트 수를 반환합니다. 파일의 끝이면 -1이 반환됩니다.

5

public int available() throws IOException{}

이 파일 입력 스트림에서 읽을 수있는 바이트 수를 제공합니다. int를 반환합니다.

사용 가능한 다른 중요한 입력 스트림이 있습니다. 자세한 내용은 다음 링크를 참조하십시오.

  • ByteArrayInputStream

  • DataInputStream

FileOutputStream

FileOutputStream은 파일을 만들고 여기에 데이터를 쓰는 데 사용됩니다. 스트림은 파일이 없으면 출력을 위해 열기 전에 파일을 생성합니다.

다음은 FileOutputStream 객체를 생성하는 데 사용할 수있는 두 개의 생성자입니다.

다음 생성자는 파일을 쓰기 위해 입력 스트림 객체를 생성하기 위해 파일 이름을 문자열로 취합니다.

OutputStream f = new FileOutputStream("C:/java/hello")

다음 생성자는 파일 객체를 사용하여 파일을 쓰기위한 출력 스트림 객체를 만듭니다. 먼저 다음과 같이 File () 메서드를 사용하여 파일 객체를 만듭니다.

File f = new File("C:/java/hello");
OutputStream f = new FileOutputStream(f);

일단 당신 의 OutputStream 손에 개체를 다음 스트리밍 또는 스트림에 다른 작업을 수행 할 쓰기에 사용할 수있는 도우미 메서드의 목록이있다.

Sr. 아니. 방법 및 설명
1

public void close() throws IOException{}

이 메서드는 파일 출력 스트림을 닫습니다. 파일과 관련된 모든 시스템 리소스를 해제합니다. IOException이 발생합니다.

2

protected void finalize()throws IOException {}

이 방법은 파일에 대한 연결을 정리합니다. 이 스트림에 대한 참조가 더 이상 없을 때이 파일 출력 스트림의 close 메소드가 호출되는지 확인합니다. IOException이 발생합니다.

public void write(int w)throws IOException{}

이 메서드는 지정된 바이트를 출력 스트림에 씁니다.

4

public void write(byte[] w)

언급 된 바이트 배열의 w.length 바이트를 OutputStream에 씁니다.

사용 가능한 다른 중요한 출력 스트림이 있습니다. 자세한 내용은 다음 링크를 참조하십시오.

  • ByteArrayOutputStream

  • DataOutputStream

Example

다음은 InputStream 및 OutputStream을 보여주는 예입니다.

import java.io.*;
public class fileStreamTest {

   public static void main(String args[]) {
   
      try {
         byte bWrite [] = {11,21,3,40,5};
         OutputStream os = new FileOutputStream("test.txt");
         for(int x = 0; x < bWrite.length ; x++) {
            os.write( bWrite[x] );   // writes the bytes
         }
         os.close();
     
         InputStream is = new FileInputStream("test.txt");
         int size = is.available();

         for(int i = 0; i < size; i++) {
            System.out.print((char)is.read() + "  ");
         }
         is.close();
      } catch (IOException e) {
         System.out.print("Exception");
      }	
   }
}

위의 코드는 test.txt 파일을 만들고 주어진 숫자를 이진 형식으로 씁니다. stdout 화면의 출력도 마찬가지입니다.

파일 탐색 및 I / O

파일 탐색 및 I / O의 기본 사항을 알기 위해 살펴볼 몇 가지 다른 클래스가 있습니다.

  • 파일 클래스

  • FileReader 클래스

  • FileWriter 클래스

자바의 디렉토리

디렉토리는 다른 파일 및 디렉토리 목록을 포함 할 수있는 파일입니다. 너는 사용한다File개체를 사용하여 디렉터리를 만들고 디렉터리에서 사용 가능한 파일을 나열합니다. 자세한 내용은 File 객체에서 호출 할 수있는 모든 메서드 목록과 디렉터리와 관련된 항목을 확인하십시오.

디렉토리 생성

두 가지 유용한 File 디렉토리 생성에 사용할 수있는 유틸리티 메소드-

  • 그만큼 mkdir( )메소드는 디렉토리를 생성하고 성공하면 true를, 실패하면 false를 반환합니다. 실패는 File 개체에 지정된 경로가 이미 존재하거나 전체 경로가 아직 존재하지 않기 때문에 디렉터리를 만들 수 없음을 나타냅니다.

  • 그만큼 mkdirs() 메소드는 디렉토리와 디렉토리의 모든 부모를 만듭니다.

다음 예제는 "/ tmp / user / java / bin"디렉토리를 생성합니다-

Example

import java.io.File;
public class CreateDir {

   public static void main(String args[]) {
      String dirname = "/tmp/user/java/bin";
      File d = new File(dirname);
      
      // Create directory now.
      d.mkdirs();
   }
}

위 코드를 컴파일하고 실행하여 "/ tmp / user / java / bin"을 생성합니다.

Note− Java는 규칙에 따라 UNIX 및 Windows에서 경로 구분자를 자동으로 처리합니다. Windows 버전의 Java에서 슬래시 (/)를 사용하면 경로가 여전히 올바르게 해석됩니다.

디렉토리 나열

당신이 사용할 수있는 list( ) 제공 방법 File 다음과 같이 디렉토리에서 사용 가능한 모든 파일과 디렉토리를 나열하는 객체-

Example

import java.io.File;
public class ReadDir {

   public static void main(String[] args) {
      File file = null;
      String[] paths;
  
      try {      
         // create new file object
         file = new File("/tmp");

         // array of files and directory
         paths = file.list();

         // for each name in the path array
         for(String path:paths) {
            // prints filename and directory name
            System.out.println(path);
         }
      } catch (Exception e) {
         // if any error occurs
         e.printStackTrace();
      }
   }
}

이렇게하면 사용 가능한 디렉토리 및 파일에 따라 다음 결과가 생성됩니다. /tmp 디렉토리-

Output

test1.txt
test2.txt
ReadDir.java
ReadDir.class

예외 (또는 예외적 이벤트)는 프로그램 실행 중에 발생하는 문제입니다. 때Exception 프로그램의 정상적인 흐름이 중단되고 프로그램 / 응용 프로그램이 비정상적으로 종료되는 경우가 발생하므로 권장되지 않으므로 이러한 예외를 처리해야합니다.

여러 가지 이유로 예외가 발생할 수 있습니다. 다음은 예외가 발생하는 몇 가지 시나리오입니다.

  • 사용자가 잘못된 데이터를 입력했습니다.

  • 열어야하는 파일을 찾을 수 없습니다.

  • 통신 중에 네트워크 연결이 끊어 졌거나 JVM의 메모리가 부족합니다.

이러한 예외 중 일부는 사용자 오류로, 다른 일부는 프로그래머 오류로, 다른 일부는 어떤 식 으로든 실패한 물리적 리소스로 인해 발생합니다.

이를 바탕으로 세 가지 범주의 예외가 있습니다. Java에서 예외 처리가 작동하는 방식을 이해하려면이를 이해해야합니다.

  • Checked exceptions− 확인 된 예외는 컴파일 시간에 컴파일러에 의해 확인 (알림)되는 예외이며 컴파일 시간 예외라고도합니다. 이러한 예외는 단순히 무시할 수 없으며 프로그래머는 이러한 예외를 처리 (처리)해야합니다.

예를 들어 FileReader생성자에 지정된 파일이 존재하지 않는 경우 프로그램의 클래스를 사용하여 파일에서 데이터를 읽으면 FileNotFoundException이 발생하고 컴파일러는 프로그래머에게 예외를 처리하도록 프롬프트합니다.

import java.io.File;
import java.io.FileReader;

public class FilenotFound_Demo {

   public static void main(String args[]) {		
      File file = new File("E://file.txt");
      FileReader fr = new FileReader(file); 
   }
}

위의 프로그램을 컴파일하려고하면 다음과 같은 예외가 발생합니다.

산출

C:\>javac FilenotFound_Demo.java
FilenotFound_Demo.java:8: error: unreported exception FileNotFoundException; must be caught or declared to be thrown
      FileReader fr = new FileReader(file);
                      ^
1 error

Note − 방법 이후 read()close() FileReader 클래스에서 IOException이 발생하면 컴파일러가 FileNotFoundException과 함께 IOException을 처리하도록 알립니다.

  • Unchecked exceptions− 확인되지 않은 예외는 실행시 발생하는 예외입니다. 이것들은 또한Runtime Exceptions. 여기에는 논리 오류 또는 부적절한 API 사용과 같은 프로그래밍 버그가 포함됩니다. 런타임 예외는 컴파일시 무시됩니다.

예를 들어, 프로그램에서 크기 5의 배열을 선언하고 배열의 6 번째 요소 를 호출하려고 하면 ArrayIndexOutOfBoundsExceptionexception 이 발생합니다.

public class Unchecked_Demo {
   
   public static void main(String args[]) {
      int num[] = {1, 2, 3, 4};
      System.out.println(num[5]);
   }
}

위의 프로그램을 컴파일하고 실행하면 다음과 같은 예외가 발생합니다.

산출

Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 5
	at Exceptions.Unchecked_Demo.main(Unchecked_Demo.java:8)
  • Errors− 이는 예외가 아니라 사용자 또는 프로그래머의 통제를 벗어난 문제입니다. 오류에 대해 거의 아무것도 할 수 없기 때문에 오류는 일반적으로 코드에서 무시됩니다. 예를 들어 스택 오버플로가 발생하면 오류가 발생합니다. 또한 컴파일시 무시됩니다.

예외 계층

모든 예외 클래스는 java.lang.Exception 클래스의 하위 유형입니다. 예외 클래스는 Throwable 클래스의 하위 클래스입니다. 예외 클래스 외에 Throwable 클래스에서 파생 된 Error라는 또 다른 하위 클래스가 있습니다.

오류는 심각한 실패시 발생하는 비정상적인 조건이며 Java 프로그램에서 처리하지 않습니다. 런타임 환경에서 생성 된 오류를 나타 내기 위해 오류가 생성됩니다. 예 : JVM에 메모리가 부족합니다. 일반적으로 프로그램은 오류에서 복구 할 수 없습니다.

Exception 클래스에는 IOException 클래스와 RuntimeException 클래스의 두 가지 주요 하위 클래스가 있습니다.

다음은 가장 일반적인 확인 및 확인되지 않은 Java의 내장 예외 목록 입니다.

예외 방법

다음은 Throwable 클래스에서 사용할 수있는 중요한 메서드 목록입니다.

Sr. 아니. 방법 및 설명
1

public String getMessage()

발생한 예외에 대한 자세한 메시지를 반환합니다. 이 메시지는 Throwable 생성자에서 초기화됩니다.

2

public Throwable getCause()

Throwable 객체가 나타내는 예외의 원인을 반환합니다.

public String toString()

getMessage ()의 결과와 연결된 클래스 이름을 반환합니다.

4

public void printStackTrace()

스택 추적과 함께 toString ()의 결과를 오류 출력 스트림 인 System.err에 인쇄합니다.

5

public StackTraceElement [] getStackTrace()

스택 추적의 각 요소를 포함하는 배열을 반환합니다. 인덱스 0의 요소는 호출 스택의 맨 위를 나타내고 배열의 마지막 요소는 호출 스택의 맨 아래에있는 메서드를 나타냅니다.

6

public Throwable fillInStackTrace()

이 Throwable 개체의 스택 추적을 현재 스택 추적으로 채우고 스택 추적의 이전 정보에 추가합니다.

예외 잡기

메소드는 다음 조합을 사용하여 예외를 포착합니다. trycatch키워드. 예외를 생성 할 수있는 코드 주위에 try / catch 블록이 배치됩니다. try / catch 블록 내의 코드를 보호 코드라고하며 try / catch를 사용하는 구문은 다음과 같습니다.

통사론

try {
   // Protected code
} catch (ExceptionName e1) {
   // Catch block
}

예외가 발생하기 쉬운 코드는 try 블록에 배치됩니다. 예외가 발생하면 발생한 예외는 연관된 catch 블록에 의해 처리됩니다. 모든 try 블록 바로 뒤에 catch 블록 또는 finally 블록이 와야합니다.

catch 문에는 catch하려는 예외 유형을 선언하는 것이 포함됩니다. 보호 코드에서 예외가 발생하면 try 다음에 나오는 catch 블록 (또는 블록)이 검사됩니다. 발생한 예외 유형이 catch 블록에 나열되어 있으면 인수가 메서드 매개 변수에 전달되는 것처럼 예외가 catch 블록에 전달됩니다.

다음은 2 개의 요소로 선언 된 배열입니다. 그런 다음 코드는 예외를 발생시키는 배열 의 세 번째 요소에 액세스하려고합니다 .

// File Name : ExcepTest.java
import java.io.*;

public class ExcepTest {

   public static void main(String args[]) {
      try {
         int a[] = new int[2];
         System.out.println("Access element three :" + a[3]);
      } catch (ArrayIndexOutOfBoundsException e) {
         System.out.println("Exception thrown  :" + e);
      }
      System.out.println("Out of the block");
   }
}

이것은 다음 결과를 생성합니다-

산출

Exception thrown  :java.lang.ArrayIndexOutOfBoundsException: 3
Out of the block

다중 캐치 블록

try 블록 뒤에 여러 catch 블록이 올 수 있습니다. 여러 catch 블록의 구문은 다음과 같습니다.

통사론

try {
   // Protected code
} catch (ExceptionType1 e1) {
   // Catch block
} catch (ExceptionType2 e2) {
   // Catch block
} catch (ExceptionType3 e3) {
   // Catch block
}

앞의 명령문은 세 개의 catch 블록을 보여 주지만 한 번의 시도 후 원하는 수만큼 가질 수 있습니다. 보호 코드에서 예외가 발생하면 목록의 첫 번째 catch 블록에 예외가 throw됩니다. throw 된 예외의 데이터 유형이 ExceptionType1과 일치하면 거기서 포착됩니다. 그렇지 않은 경우 예외는 두 번째 catch 문으로 전달됩니다. 이는 예외가 포착되거나 모든 포착을 통과 할 때까지 계속됩니다.이 경우 현재 메서드가 실행을 중지하고 예외가 호출 스택의 이전 메서드로 throw됩니다.

다음은 여러 try / catch 문을 사용하는 방법을 보여주는 코드 세그먼트입니다.

try {
   file = new FileInputStream(fileName);
   x = (byte) file.read();
} catch (IOException i) {
   i.printStackTrace();
   return -1;
} catch (FileNotFoundException f) // Not valid! {
   f.printStackTrace();
   return -1;
}

여러 유형의 예외 포착

Java 7부터는 단일 catch 블록을 사용하여 둘 이상의 예외를 처리 할 수 ​​있으므로이 기능은 코드를 단순화합니다. 방법은 다음과 같습니다.

catch (IOException|FileNotFoundException ex) {
   logger.log(ex);
   throw ex;

Throws / Throw 키워드

메서드가 확인 된 예외를 처리하지 않는 경우 메서드는 throws예어. throws 키워드는 메서드의 서명 끝에 나타납니다.

다음을 사용하여 새로 인스턴스화 된 예외 또는 방금 포착 한 예외를 throw 할 수 있습니다. throw 예어.

throws와 throw 키워드의 차이점을 이해하려고하면 throws 는 확인 된 예외 처리를 연기하는 데 사용되고 throw 는 명시 적으로 예외를 호출하는 데 사용됩니다.

다음 메소드는 RemoteException이 발생한다고 선언합니다.

import java.io.*;
public class className {

   public void deposit(double amount) throws RemoteException {
      // Method implementation
      throw new RemoteException();
   }
   // Remainder of class definition
}

메서드는 둘 이상의 예외를 throw한다고 선언 할 수 있습니다.이 경우 예외는 쉼표로 구분 된 목록에 선언됩니다. 예를 들어, 다음 메소드는 RemoteException과 InsufficientFundsException을 던진다 고 선언합니다.

import java.io.*;
public class className {

   public void withdraw(double amount) throws RemoteException, 
      InsufficientFundsException {
      // Method implementation
   }
   // Remainder of class definition
}

마지막 블록

finally 블록은 try 블록 또는 catch 블록을 따릅니다. finally 코드 블록은 예외 발생에 관계없이 항상 실행됩니다.

finally 블록을 사용하면 보호 된 코드에서 어떤 일이 발생하더라도 실행하려는 정리 유형 문을 실행할 수 있습니다.

finally 블록은 catch 블록의 끝에 나타나며 다음 구문을 사용합니다.

통사론

try {
   // Protected code
} catch (ExceptionType1 e1) {
   // Catch block
} catch (ExceptionType2 e2) {
   // Catch block
} catch (ExceptionType3 e3) {
   // Catch block
}finally {
   // The finally block always executes.
}

public class ExcepTest {

   public static void main(String args[]) {
      int a[] = new int[2];
      try {
         System.out.println("Access element three :" + a[3]);
      } catch (ArrayIndexOutOfBoundsException e) {
         System.out.println("Exception thrown  :" + e);
      }finally {
         a[0] = 6;
         System.out.println("First element value: " + a[0]);
         System.out.println("The finally statement is executed");
      }
   }
}

이것은 다음 결과를 생성합니다-

산출

Exception thrown  :java.lang.ArrayIndexOutOfBoundsException: 3
First element value: 6
The finally statement is executed

다음을 참고하십시오-

  • try 문없이 catch 절은 존재할 수 없습니다.

  • try / catch 블록이있을 때마다 finally 절을 가질 필요는 없습니다.

  • try 블록은 catch 절이나 finally 절 없이는 존재할 수 없습니다.

  • try, catch, finally 블록 사이에는 어떤 코드도 존재할 수 없습니다.

시도 자원

일반적으로 스트림, 연결 등과 같은 리소스를 사용할 때 finally 블록을 사용하여 명시 적으로 닫아야합니다. 다음 프로그램에서는 다음을 사용하여 파일에서 데이터를 읽습니다.FileReader 그리고 finally 블록을 사용하여 닫습니다.

import java.io.File;
import java.io.FileReader;
import java.io.IOException;

public class ReadData_Demo {

   public static void main(String args[]) {
      FileReader fr = null;		
      try {
         File file = new File("file.txt");
         fr = new FileReader(file); char [] a = new char[50];
         fr.read(a);   // reads the content to the array
         for(char c : a)
         System.out.print(c);   // prints the characters one by one
      } catch (IOException e) {
         e.printStackTrace();
      }finally {
         try {
            fr.close();
         } catch (IOException ex) {		
            ex.printStackTrace();
         }
      }
   }
}

try-with-resources, 일컬어 automatic resource management는 try catch 블록 내에서 사용되는 리소스를 자동으로 닫는 Java 7에 도입 된 새로운 예외 처리 메커니즘입니다.

이 문을 사용하려면 괄호 안에 필요한 리소스를 선언하기 만하면됩니다. 생성 된 리소스는 블록 끝에서 자동으로 닫힙니다. 다음은 try-with-resources 문의 구문입니다.

통사론

try(FileReader fr = new FileReader("file path")) {
   // use the resource
   } catch () {
      // body of catch 
   }
}

다음은 try-with-resources 문을 사용하여 파일의 데이터를 읽는 프로그램입니다.

import java.io.FileReader;
import java.io.IOException;

public class Try_withDemo {

   public static void main(String args[]) {
      try(FileReader fr = new FileReader("E://file.txt")) {
         char [] a = new char[50];
         fr.read(a);   // reads the contentto the array
         for(char c : a)
         System.out.print(c);   // prints the characters one by one
      } catch (IOException e) {
         e.printStackTrace();
      }
   }
}

try-with-resources 문을 사용하는 동안 다음 사항을 염두에 두어야합니다.

  • try-with-resources 문으로 클래스를 사용하려면 다음을 구현해야합니다. AutoCloseable 인터페이스 및 close() 그것의 메서드는 런타임에 자동으로 호출됩니다.

  • try-with-resources 문에서 둘 이상의 클래스를 선언 할 수 있습니다.

  • try-with-resources 문의 try 블록에서 여러 클래스를 선언하는 동안 이러한 클래스는 역순으로 닫힙니다.

  • 괄호 안의 리소스 선언을 제외하고 모든 것은 try 블록의 일반 try / catch 블록과 동일합니다.

  • try에서 선언 된 리소스는 try-block이 시작되기 직전에 인스턴스화됩니다.

  • try 블록에서 선언 된 리소스는 암시 적으로 final로 선언됩니다.

사용자 정의 예외

Java에서 고유 한 예외를 만들 수 있습니다. 자신의 예외 클래스를 작성할 때 다음 사항을 염두에 두십시오.

  • 모든 예외는 Throwable의 자식이어야합니다.

  • Handle 또는 Declare Rule에 의해 자동으로 적용되는 확인 된 예외를 작성하려면 Exception 클래스를 확장해야합니다.

  • 런타임 예외를 작성하려면 RuntimeException 클래스를 확장해야합니다.

아래와 같이 Exception 클래스를 정의 할 수 있습니다.

class MyException extends Exception {
}

미리 정의 된 Exception클래스를 사용하여 자신의 예외를 만듭니다. 이는 확인 된 예외로 간주됩니다. 다음과 같은InsufficientFundsExceptionclass는 Exception 클래스를 확장하여 확인 된 예외로 만드는 사용자 정의 예외입니다. 예외 클래스는 유용한 필드와 메서드를 포함하는 다른 클래스와 같습니다.

// File Name InsufficientFundsException.java
import java.io.*;

public class InsufficientFundsException extends Exception {
   private double amount;
   
   public InsufficientFundsException(double amount) {
      this.amount = amount;
   }
   
   public double getAmount() {
      return amount;
   }
}

사용자 정의 예외 사용을 보여주기 위해 다음 CheckingAccount 클래스에는 InsufficientFundsException을 발생시키는 withdraw () 메서드가 포함되어 있습니다.

// File Name CheckingAccount.java
import java.io.*;

public class CheckingAccount {
   private double balance;
   private int number;
   
   public CheckingAccount(int number) {
      this.number = number;
   }
   
   public void deposit(double amount) {
      balance += amount;
   }
   
   public void withdraw(double amount) throws InsufficientFundsException {
      if(amount <= balance) {
         balance -= amount;
      }else {
         double needs = amount - balance;
         throw new InsufficientFundsException(needs);
      }
   }
   
   public double getBalance() {
      return balance;
   }
   
   public int getNumber() {
      return number;
   }
}

다음 BankDemo 프로그램은 CheckingAccount의 deposit () 및 withdraw () 메소드를 호출하는 방법을 보여줍니다.

// File Name BankDemo.java
public class BankDemo {

   public static void main(String [] args) {
      CheckingAccount c = new CheckingAccount(101);
      System.out.println("Depositing $500..."); c.deposit(500.00); try { System.out.println("\nWithdrawing $100...");
         c.withdraw(100.00);
         System.out.println("\nWithdrawing $600..."); c.withdraw(600.00); } catch (InsufficientFundsException e) { System.out.println("Sorry, but you are short $" + e.getAmount());
         e.printStackTrace();
      }
   }
}

위의 세 파일을 모두 컴파일하고 BankDemo를 실행합니다. 이것은 다음 결과를 생성합니다-

산출

Depositing $500... Withdrawing $100...

Withdrawing $600... Sorry, but you are short $200.0
InsufficientFundsException
         at CheckingAccount.withdraw(CheckingAccount.java:25)
         at BankDemo.main(BankDemo.java:13)

일반적인 예외

Java에서는 예외 및 오류의 두 범주를 정의 할 수 있습니다.

  • JVM Exceptions− 이는 JVM에서 배타적으로 또는 논리적으로 발생하는 예외 / 오류입니다. 예 : NullPointerException, ArrayIndexOutOfBoundsException, ClassCastException.

  • Programmatic Exceptions− 이러한 예외는 애플리케이션 또는 API 프로그래머에 의해 명시 적으로 발생합니다. 예 : IllegalArgumentException, IllegalStateException.

이 장에서는 Java의 내부 클래스에 대해 설명합니다.

중첩 클래스

Java에서는 메소드와 마찬가지로 클래스의 변수도 다른 클래스를 멤버로 가질 수 있습니다. 다른 클래스 내에서 클래스를 작성하는 것은 Java에서 허용됩니다. 내부에 작성된 클래스는nested class, 내부 클래스를 보유하는 클래스를 outer class.

Syntax

다음은 중첩 클래스를 작성하는 구문입니다. 여기, 수업Outer_Demo 외부 클래스와 클래스 Inner_Demo 중첩 클래스입니다.

class Outer_Demo {
   class Inner_Demo {
   }
}

중첩 클래스는 두 가지 유형으로 나뉩니다.

  • Non-static nested classes − 이들은 클래스의 비 정적 멤버입니다.

  • Static nested classes − 이들은 클래스의 정적 멤버입니다.

내부 클래스 (비 정적 중첩 클래스)

내부 클래스는 Java의 보안 메커니즘입니다. 클래스는 액세스 수정 자와 연관 될 수 없음을 알고 있습니다.private하지만 클래스가 다른 클래스의 멤버로있는 경우 내부 클래스를 비공개로 만들 수 있습니다. 그리고 이것은 클래스의 개인 멤버에 액세스하는데도 사용됩니다.

내부 클래스는 정의 방법과 위치에 따라 세 가지 유형이 있습니다. 그들은-

  • 이너 클래스
  • 메서드 로컬 내부 클래스
  • 익명 내부 클래스

이너 클래스

내부 클래스를 만드는 것은 매우 간단합니다. 클래스 내에서 클래스를 작성하기 만하면됩니다. 클래스와 달리 내부 클래스는 private 일 수 있으며 일단 내부 클래스를 private으로 선언하면 클래스 외부의 개체에서 액세스 할 수 없습니다.

다음은 내부 클래스를 만들고 액세스하는 프로그램입니다. 주어진 예제에서 우리는 내부 클래스를 비공개로 만들고 메서드를 통해 클래스에 액세스합니다.

Example

class Outer_Demo {
   int num;
   
   // inner class
   private class Inner_Demo {
      public void print() {
         System.out.println("This is an inner class");
      }
   }
   
   // Accessing he inner class from the method within
   void display_Inner() {
      Inner_Demo inner = new Inner_Demo();
      inner.print();
   }
}
   
public class My_class {

   public static void main(String args[]) {
      // Instantiating the outer class 
      Outer_Demo outer = new Outer_Demo();
      
      // Accessing the display_Inner() method.
      outer.display_Inner();
   }
}

여기서 당신은 Outer_Demo 외부 클래스입니다. Inner_Demo 내부 클래스입니다. display_Inner() 내부 클래스를 인스턴스화하는 메서드이며이 메서드는 main 방법.

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과를 얻을 수 있습니다.

Output

This is an inner class.

개인 회원 액세스

앞서 언급했듯이 내부 클래스는 클래스의 개인 멤버에 액세스하는데도 사용됩니다. 클래스에 액세스 할 수있는 개인 멤버가 있다고 가정합니다. 내부 클래스를 작성하고 내부 클래스 내의 메서드에서 전용 멤버를 반환합니다.getValue()그리고 마지막으로 다른 클래스 (개인 멤버에 액세스하려는)에서 내부 클래스의 getValue () 메서드를 호출합니다.

내부 클래스를 인스턴스화하려면 처음에 외부 클래스를 인스턴스화해야합니다. 그 후 외부 클래스의 객체를 사용하여 내부 클래스를 인스턴스화하는 방법은 다음과 같습니다.

Outer_Demo outer = new Outer_Demo();
Outer_Demo.Inner_Demo inner = outer.new Inner_Demo();

다음 프로그램은 내부 클래스를 사용하여 클래스의 개인 멤버에 액세스하는 방법을 보여줍니다.

Example

class Outer_Demo {
   // private variable of the outer class
   private int num = 175;  
   
   // inner class
   public class Inner_Demo {
      public int getNum() {
         System.out.println("This is the getnum method of the inner class");
         return num;
      }
   }
}

public class My_class2 {

   public static void main(String args[]) {
      // Instantiating the outer class
      Outer_Demo outer = new Outer_Demo();
      
      // Instantiating the inner class
      Outer_Demo.Inner_Demo inner = outer.new Inner_Demo();
      System.out.println(inner.getNum());
   }
}

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과를 얻을 수 있습니다.

Output

This is the getnum method of the inner class: 175

메서드 로컬 내부 클래스

Java에서는 메서드 내에 클래스를 작성할 수 있으며 이것은 로컬 유형이됩니다. 지역 변수와 마찬가지로 내부 클래스의 범위는 메서드 내에서 제한됩니다.

메서드 로컬 내부 클래스는 내부 클래스가 정의 된 메서드 내에서만 인스턴스화 될 수 있습니다. 다음 프로그램은 메서드 로컬 내부 클래스를 사용하는 방법을 보여줍니다.

Example

public class Outerclass {
   // instance method of the outer class 
   void my_Method() {
      int num = 23;

      // method-local inner class
      class MethodInner_Demo {
         public void print() {
            System.out.println("This is method inner class "+num);	   
         }   
      } // end of inner class
	   
      // Accessing the inner class
      MethodInner_Demo inner = new MethodInner_Demo();
      inner.print();
   }
   
   public static void main(String args[]) {
      Outerclass outer = new Outerclass();
      outer.my_Method();	   	   
   }
}

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과를 얻을 수 있습니다.

Output

This is method inner class 23

익명 내부 클래스

클래스 이름없이 선언 된 내부 클래스는 anonymous inner class. 익명 내부 클래스의 경우 동시에 선언하고 인스턴스화합니다. 일반적으로 클래스 또는 인터페이스의 메서드를 재정의해야 할 때마다 사용됩니다. 익명의 내부 클래스의 구문은 다음과 같습니다.

Syntax

AnonymousInner an_inner = new AnonymousInner() {
   public void my_method() {
      ........
      ........
   }   
};

다음 프로그램은 익명 내부 클래스를 사용하여 클래스의 메서드를 재정의하는 방법을 보여줍니다.

Example

abstract class AnonymousInner {
   public abstract void mymethod();
}

public class Outer_class {

   public static void main(String args[]) {
      AnonymousInner inner = new AnonymousInner() {
         public void mymethod() {
            System.out.println("This is an example of anonymous inner class");
         }
      };
      inner.mymethod();	
   }
}

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과를 얻을 수 있습니다.

Output

This is an example of anonymous inner class

같은 방식으로 익명 내부 클래스를 사용하여 인터페이스뿐만 아니라 구체적인 클래스의 메서드를 재정의 할 수 있습니다.

인수로서의 익명 내부 클래스

일반적으로 메서드가 인터페이스, 추상 클래스 또는 구체적인 클래스의 개체를 수락하면 인터페이스를 구현하고 추상 클래스를 확장 한 다음 개체를 메서드에 전달할 수 있습니다. 클래스 인 경우 메서드에 직접 전달할 수 있습니다.

그러나 세 가지 경우 모두 익명의 내부 클래스를 메서드에 전달할 수 있습니다. 다음은 익명의 내부 클래스를 메서드 인수로 전달하는 구문입니다.

obj.my_Method(new My_Class() {
   public void Do() {
      .....
      .....
   }
});

다음 프로그램은 익명의 내부 클래스를 메서드 인수로 전달하는 방법을 보여줍니다.

Example

// interface
interface Message {
   String greet();
}

public class My_class {
   // method which accepts the object of interface Message
   public void displayMessage(Message m) {
      System.out.println(m.greet() +
         ", This is an example of anonymous inner class as an argument");  
   }

   public static void main(String args[]) {
      // Instantiating the class
      My_class obj = new My_class();

      // Passing an anonymous inner class as an argument
      obj.displayMessage(new Message() {
         public String greet() {
            return "Hello";
         }
      });
   }
}

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과를 얻을 수 있습니다.

Output

Hello, This is an example of anonymous inner class as an argument

정적 중첩 클래스

정적 내부 클래스는 외부 클래스의 정적 멤버 인 중첩 클래스입니다. 다른 정적 멤버를 사용하여 외부 클래스를 인스턴스화하지 않고도 액세스 할 수 있습니다. 정적 멤버와 마찬가지로 정적 중첩 클래스는 외부 클래스의 인스턴스 변수 및 메서드에 액세스 할 수 없습니다. 정적 중첩 클래스의 구문은 다음과 같습니다.

Syntax

class MyOuter {
   static class Nested_Demo {
   }
}

정적 중첩 클래스를 인스턴스화하는 것은 내부 클래스를 인스턴스화하는 것과 약간 다릅니다. 다음 프로그램은 정적 중첩 클래스를 사용하는 방법을 보여줍니다.

Example

public class Outer {
   static class Nested_Demo {
      public void my_method() {
         System.out.println("This is my nested class");
      }
   }
   
   public static void main(String args[]) {
      Outer.Nested_Demo nested = new Outer.Nested_Demo();	 
      nested.my_method();
   }
}

위의 프로그램을 컴파일하고 실행하면 다음과 같은 결과를 얻을 수 있습니다.

Output

This is my nested class

상속은 한 클래스가 다른 클래스의 속성 (메서드 및 필드)을 획득하는 프로세스로 정의 할 수 있습니다. 상속을 사용하면 정보를 계층 적 순서로 관리 할 수 ​​있습니다.

other의 속성을 상속하는 클래스를 하위 클래스 (파생 클래스, 자식 클래스)라고하고 속성이 상속 된 클래스를 수퍼 클래스 (기본 클래스, 부모 클래스)라고합니다.

키워드 확장

extends클래스의 속성을 상속하는 데 사용되는 키워드입니다. 다음은 extends 키워드의 구문입니다.

Syntax

class Super {
   .....
   .....
}
class Sub extends Super {
   .....
   .....
}

샘플 코드

다음은 Java 상속을 보여주는 예입니다. 이 예제에서는 Calculation과 My_Calculation이라는 두 클래스를 관찰 할 수 있습니다.

extends 키워드를 사용하여 My_Calculation은 Calculation 클래스의 addition () 및 Subtraction () 메소드를 상속합니다.

My_Calculation.java라는 파일에 다음 프로그램을 복사하여 붙여 넣습니다.

Example

class Calculation {
   int z;
	
   public void addition(int x, int y) {
      z = x + y;
      System.out.println("The sum of the given numbers:"+z);
   }
	
   public void Subtraction(int x, int y) {
      z = x - y;
      System.out.println("The difference between the given numbers:"+z);
   }
}

public class My_Calculation extends Calculation {
   public void multiplication(int x, int y) {
      z = x * y;
      System.out.println("The product of the given numbers:"+z);
   }
	
   public static void main(String args[]) {
      int a = 20, b = 10;
      My_Calculation demo = new My_Calculation();
      demo.addition(a, b);
      demo.Subtraction(a, b);
      demo.multiplication(a, b);
   }
}

아래와 같이 위의 코드를 컴파일하고 실행합니다.

javac My_Calculation.java
java My_Calculation

프로그램을 실행하면 다음 결과가 생성됩니다.

Output

The sum of the given numbers:30
The difference between the given numbers:10
The product of the given numbers:200

주어진 프로그램에서 객체가 My_Calculation클래스가 생성되면 그 안에 수퍼 클래스의 내용 사본이 만들어집니다. 그렇기 때문에 서브 클래스의 객체를 사용하여 슈퍼 클래스의 멤버에 액세스 할 수 있습니다.

수퍼 클래스 참조 변수는 서브 클래스 객체를 보유 할 수 있지만 해당 변수를 사용하면 수퍼 클래스의 멤버에만 액세스 할 수 있으므로 두 클래스의 멤버에 액세스하려면 항상 서브 클래스에 대한 참조 변수를 만드는 것이 좋습니다.

위의 프로그램을 고려하면 아래와 같이 클래스를 인스턴스화 할 수 있습니다. 그러나 수퍼 클래스 참조 변수 (cal 이 경우) 메서드를 호출 할 수 없습니다. multiplication()하위 클래스 My_Calculation에 속합니다.

Calculation demo = new My_Calculation();
demo.addition(a, b);
demo.Subtraction(a, b);

Note− 서브 클래스는 수퍼 클래스에서 모든 멤버 (필드, 메소드 및 중첩 클래스)를 상속합니다. 생성자는 멤버가 아니므로 하위 클래스에서 상속되지 않지만 수퍼 클래스의 생성자는 하위 클래스에서 호출 할 수 있습니다.

슈퍼 키워드

그만큼 super 키워드가 this예어. 다음은 super 키워드가 사용되는 시나리오입니다.

  • 그것은에 사용됩니다 differentiate the members 동일한 이름을 가진 경우 하위 클래스의 구성원에서 수퍼 클래스의.

  • 그것은에 사용됩니다 invoke the superclass 하위 클래스의 생성자.

회원 차별화

클래스가 다른 클래스의 속성을 상속하는 경우. 그리고 슈퍼 클래스의 멤버가 서브 클래스와 이름이 같은 경우 이러한 변수를 구별하기 위해 아래와 같이 super 키워드를 사용합니다.

super.variable
super.method();

샘플 코드

이 섹션에서는 사용 방법을 보여주는 프로그램을 제공합니다. super 예어.

주어진 프로그램에는 Sub_classSuper_class 라는 두 개의 클래스 가 있으며 둘 다 구현이 다른 display ()라는 메서드와 다른 값을 가진 num이라는 변수가 있습니다. 두 클래스의 display () 메서드를 호출하고 두 클래스의 변수 num 값을 인쇄합니다. 여기에서 super 키워드를 사용하여 superclass의 멤버와 subclass를 구별하는 것을 볼 수 있습니다.

이름이 Sub_class.java 인 파일에 프로그램을 복사하여 붙여 넣으십시오.

Example

class Super_class {
   int num = 20;

   // display method of superclass
   public void display() {
      System.out.println("This is the display method of superclass");
   }
}

public class Sub_class extends Super_class {
   int num = 10;

   // display method of sub class
   public void display() {
      System.out.println("This is the display method of subclass");
   }

   public void my_method() {
      // Instantiating subclass
      Sub_class sub = new Sub_class();

      // Invoking the display() method of sub class
      sub.display();

      // Invoking the display() method of superclass
      super.display();

      // printing the value of variable num of subclass
      System.out.println("value of the variable named num in sub class:"+ sub.num);

      // printing the value of variable num of superclass
      System.out.println("value of the variable named num in super class:"+ super.num);
   }

   public static void main(String args[]) {
      Sub_class obj = new Sub_class();
      obj.my_method();
   }
}

다음 구문을 사용하여 위 코드를 컴파일하고 실행합니다.

javac Super_Demo
java Super

프로그램을 실행하면 다음과 같은 결과가 나타납니다.

Output

This is the display method of subclass
This is the display method of superclass
value of the variable named num in sub class:10
value of the variable named num in super class:20

슈퍼 클래스 생성자 호출

클래스가 다른 클래스의 속성을 상속하는 경우 하위 클래스는 슈퍼 클래스의 기본 생성자를 자동으로 가져옵니다. 그러나 수퍼 클래스의 매개 변수화 된 생성자를 호출하려면 아래와 같이 super 키워드를 사용해야합니다.

super(values);

샘플 코드

이 섹션에 제공된 프로그램은 super 키워드를 사용하여 수퍼 클래스의 Parameterized 생성자를 호출하는 방법을 보여줍니다. 이 프로그램은 수퍼 클래스와 서브 클래스를 포함하는데, 수퍼 클래스는 정수 값을 받아들이는 매개 변수화 된 생성자를 포함하고 있으며 우리는 super 키워드를 사용하여 수퍼 클래스의 매개 변수화 된 생성자를 호출했습니다.

다음 프로그램을 Subclass.java라는 파일에 복사하여 붙여 넣으십시오.

Example

class Superclass {
   int age;

   Superclass(int age) {
      this.age = age; 		 
   }

   public void getAge() {
      System.out.println("The value of the variable named age in super class is: " +age);
   }
}

public class Subclass extends Superclass {
   Subclass(int age) {
      super(age);
   }

   public static void main(String args[]) {
      Subclass s = new Subclass(24);
      s.getAge();
   }
}

다음 구문을 사용하여 위 코드를 컴파일하고 실행합니다.

javac Subclass
java Subclass

프로그램을 실행하면 다음과 같은 결과가 나타납니다.

Output

The value of the variable named age in super class is: 24

IS-A 관계

IS-A는 다음과 같은 표현입니다.이 개체는 그 개체의 유형입니다. 우리가 어떻게extends 키워드는 상속을 달성하는 데 사용됩니다.

public class Animal {
}

public class Mammal extends Animal {
}

public class Reptile extends Animal {
}

public class Dog extends Mammal {
}

이제 위의 예를 기반으로 객체 지향 용어로 다음이 참입니다.

  • 동물은 포유류 클래스의 수퍼 클래스입니다.
  • 동물은 파충류 클래스의 수퍼 클래스입니다.
  • 포유류와 파충류는 Animal 클래스의 하위 클래스입니다.
  • Dog는 Mammal 및 Animal 클래스의 하위 클래스입니다.

이제 IS-A 관계를 고려하면 다음과 같이 말할 수 있습니다.

  • 포유류 IS-A 동물
  • 파충류 IS-A 동물
  • 개 IS-A 포유류
  • 따라서 개는 동물이기도합니다.

extends 키워드를 사용하면 서브 클래스가 수퍼 클래스의 개인 속성을 제외한 수퍼 클래스의 모든 속성을 상속 할 수 있습니다.

인스턴스 연산자를 사용하면 Mammal이 실제로 Animal임을 확인할 수 있습니다.

Example

class Animal {
}

class Mammal extends Animal {
}

class Reptile extends Animal {
}

public class Dog extends Mammal {

   public static void main(String args[]) {
      Animal a = new Animal();
      Mammal m = new Mammal();
      Dog d = new Dog();

      System.out.println(m instanceof Animal);
      System.out.println(d instanceof Mammal);
      System.out.println(d instanceof Animal);
   }
}

이것은 다음 결과를 생성합니다-

Output

true
true
true

우리가 잘 이해하고 있기 때문에 extends 키워드, 어떻게 implements 키워드는 IS-A 관계를 얻는 데 사용됩니다.

일반적으로 implements키워드는 인터페이스의 속성을 상속하기 위해 클래스와 함께 사용됩니다. 인터페이스는 클래스에 의해 확장 될 수 없습니다.

Example

public interface Animal {
}

public class Mammal implements Animal {
}

public class Dog extends Mammal {
}

instanceof 키워드

사용하자 instanceof 운영자는 포유류가 실제로 동물이고 개가 실제로 동물인지 확인합니다.

Example

interface Animal{}
class Mammal implements Animal{}

public class Dog extends Mammal {

   public static void main(String args[]) {
      Mammal m = new Mammal();
      Dog d = new Dog();

      System.out.println(m instanceof Animal);
      System.out.println(d instanceof Mammal);
      System.out.println(d instanceof Animal);
   }
}

이것은 다음 결과를 생성합니다-

Output

true
true
true

HAS-A 관계

이러한 관계는 주로 사용법을 기반으로합니다. 이것은 특정 클래스가HAS-A특정한 것. 이 관계는 코드의 중복과 버그를 줄이는 데 도움이됩니다.

예를 들어 보겠습니다.

Example

public class Vehicle{}
public class Speed{}

public class Van extends Vehicle {
   private Speed sp;
}

이것은 클래스 Van HAS-A Speed를 보여줍니다. Speed에 대해 별도의 클래스를 사용하면 속도에 속하는 전체 코드를 Van 클래스에 넣을 필요가 없으므로 여러 응용 프로그램에서 Speed ​​클래스를 재사용 할 수 있습니다.

객체 지향 기능에서 사용자는 실제 작업을 수행하는 객체에 대해 신경 쓸 필요가 없습니다. 이를 위해 Van 클래스는 Van 클래스의 사용자에게 구현 세부 정보를 숨 깁니다. 따라서 기본적으로 사용자는 Van 클래스에게 특정 작업을 요청하고 Van 클래스는 자체적으로 작업을 수행하거나 다른 클래스에 해당 작업을 수행하도록 요청합니다.

상속 유형

아래와 같이 다양한 유형의 상속이 있습니다.

기억해야 할 매우 중요한 사실은 Java가 다중 상속을 지원하지 않는다는 것입니다. 이것은 한 클래스가 둘 이상의 클래스를 확장 할 수 없음을 의미합니다. 따라서 다음은 불법입니다-

Example

public class extends Animal, Mammal{}

그러나 클래스는 하나 이상의 인터페이스를 구현할 수 있으므로 Java가 다중 상속의 불가능 성을 제거하는 데 도움이되었습니다.

이전 장에서 우리는 슈퍼 클래스와 서브 클래스에 대해 이야기했습니다. 클래스가 수퍼 클래스에서 메서드를 상속하는 경우 final로 표시되지 않은 경우 메서드를 재정의 할 수 있습니다.

재정의의 이점은 하위 클래스 유형에 특정한 동작을 정의 할 수 있다는 것입니다. 이는 하위 클래스가 요구 사항에 따라 상위 클래스 메서드를 구현할 수 있음을 의미합니다.

객체 지향 용어에서 재정의는 기존 메서드의 기능을 재정의하는 것을 의미합니다.

예를 살펴 보겠습니다.

class Animal {
   public void move() {
      System.out.println("Animals can move");
   }
}

class Dog extends Animal {
   public void move() {
      System.out.println("Dogs can walk and run");
   }
}

public class TestDog {

   public static void main(String args[]) {
      Animal a = new Animal();   // Animal reference and object
      Animal b = new Dog();   // Animal reference but Dog object

      a.move();   // runs the method in Animal class
      b.move();   // runs the method in Dog class
   }
}

이것은 다음 결과를 생성합니다-

산출

Animals can move
Dogs can walk and run

위의 예에서는 bDog 클래스에서 move 메서드를 실행하는 Animal 유형입니다. 그 이유는 다음과 같습니다. 컴파일 타임에 참조 유형을 확인합니다. 그러나 런타임에서 JVM은 객체 유형을 파악하고 해당 특정 객체에 속하는 메소드를 실행합니다.

따라서 위의 예에서는 Animal 클래스에 move 메서드가 있으므로 프로그램이 제대로 컴파일됩니다. 그런 다음 런타임에 해당 개체에 특정한 메서드를 실행합니다.

다음 예를 고려하십시오-

class Animal {
   public void move() {
      System.out.println("Animals can move");
   }
}

class Dog extends Animal {
   public void move() {
      System.out.println("Dogs can walk and run");
   }
   public void bark() {
      System.out.println("Dogs can bark");
   }
}

public class TestDog {

   public static void main(String args[]) {
      Animal a = new Animal();   // Animal reference and object
      Animal b = new Dog();   // Animal reference but Dog object

      a.move();   // runs the method in Animal class
      b.move();   // runs the method in Dog class
      b.bark();
   }
}

이것은 다음 결과를 생성합니다-

산출

TestDog.java:26: error: cannot find symbol
      b.bark();
       ^
  symbol:   method bark()
  location: variable b of type Animal
1 error

이 프로그램은 b의 참조 유형 Animal에 bark라는 이름의 메서드가 없기 때문에 컴파일 시간 오류가 발생합니다.

메서드 재정의 규칙

  • 인수 목록은 재정의 된 메서드의 목록과 정확히 동일해야합니다.

  • 반환 유형은 수퍼 클래스의 원래 재정의 된 메서드에서 선언 된 반환 유형의 하위 유형이거나 동일해야합니다.

  • 액세스 수준은 재정의 된 메서드의 액세스 수준보다 더 제한적일 수 없습니다. 예 : 수퍼 클래스 메소드가 public으로 선언되면 하위 클래스의 대체 메소드는 private 또는 protected가 될 수 없습니다.

  • 인스턴스 메서드는 하위 클래스에서 상속 된 경우에만 재정의 할 수 있습니다.

  • final로 선언 된 메서드는 재정의 할 수 없습니다.

  • static으로 선언 된 메서드는 재정의 할 수 없지만 다시 선언 할 수 있습니다.

  • 메서드를 상속 할 수 없으면 재정의 할 수 없습니다.

  • 인스턴스의 수퍼 클래스와 동일한 패키지 내의 서브 클래스는 private 또는 final로 선언되지 않은 모든 수퍼 클래스 메서드를 재정의 할 수 있습니다.

  • 다른 패키지의 하위 클래스는 public 또는 protected로 선언 된 비 최종 메서드 만 재정의 할 수 있습니다.

  • 재정의 메서드는 재정의 된 메서드가 예외를 throw하는지 여부에 관계없이 검사 해제 예외를 throw 할 수 있습니다. 그러나 재정의 메서드는 재정의 된 메서드에 의해 선언 된 것보다 새롭거나 광범위한 검사 된 예외를 throw해서는 안됩니다. 재정의 메서드는 재정의 된 메서드보다 더 좁거나 더 적은 예외를 throw 할 수 있습니다.

  • 생성자는 재정의 할 수 없습니다.

super 키워드 사용

재정의 된 메서드의 슈퍼 클래스 버전을 호출 할 때 super 키워드가 사용됩니다.

class Animal {
   public void move() {
      System.out.println("Animals can move");
   }
}

class Dog extends Animal {
   public void move() {
      super.move();   // invokes the super class method
      System.out.println("Dogs can walk and run");
   }
}

public class TestDog {

   public static void main(String args[]) {
      Animal b = new Dog();   // Animal reference but Dog object
      b.move();   // runs the method in Dog class
   }
}

이것은 다음 결과를 생성합니다-

산출

Animals can move
Dogs can walk and run

다형성은 객체가 다양한 형태를 취하는 능력입니다. OOP에서 다형성의 가장 일반적인 사용은 부모 클래스 참조가 자식 클래스 개체를 참조하는 데 사용될 때 발생합니다.

둘 이상의 IS-A 테스트를 통과 할 수있는 모든 Java 객체는 다형성으로 간주됩니다. Java에서는 모든 객체가 자체 유형 및 객체 클래스에 대한 IS-A 테스트를 통과하므로 모든 Java 객체는 다형성입니다.

객체에 액세스하는 유일한 방법은 참조 변수를 통하는 것임을 아는 것이 중요합니다. 참조 변수는 한 가지 유형 만 될 수 있습니다. 일단 선언되면 참조 변수의 유형을 변경할 수 없습니다.

참조 변수는 final로 선언되지 않은 경우 다른 개체에 다시 할당 할 수 있습니다. 참조 변수의 유형은 개체에서 호출 할 수있는 메서드를 결정합니다.

참조 변수는 선언 된 유형의 모든 객체 또는 선언 된 유형의 하위 유형을 참조 할 수 있습니다. 참조 변수는 클래스 또는 인터페이스 유형으로 선언 할 수 있습니다.

예를 살펴 보겠습니다.

public interface Vegetarian{}
public class Animal{}
public class Deer extends Animal implements Vegetarian{}

이제 Deer 클래스는 다중 상속이 있기 때문에 다형성으로 간주됩니다. 위의 예는 다음과 같습니다.

  • 사슴 IS-A 동물
  • 사슴 IS-A 채식주의 자
  • 사슴 IS-A 사슴
  • 사슴 IS-A 개체

참조 변수 팩트를 Deer 객체 참조에 적용하면 다음 선언이 합법적입니다.

Deer d = new Deer();
Animal a = d;
Vegetarian v = d;
Object o = d;

모든 참조 변수 d, a, v, o는 힙의 동일한 Deer 개체를 참조합니다.

가상 방법

이 섹션에서는 Java에서 재정의 된 메서드의 동작을 통해 클래스를 설계 할 때 다형성을 활용할 수있는 방법을 보여줍니다.

이미 메서드 재정의에 대해 논의했습니다. 여기서 자식 클래스는 부모의 메서드를 재정의 할 수 있습니다. 재정의 된 메서드는 기본적으로 부모 클래스에 숨겨져 있으며 자식 클래스가 재정의 메서드 내에서 super 키워드를 사용하지 않는 한 호출되지 않습니다.

/* File name : Employee.java */
public class Employee {
   private String name;
   private String address;
   private int number;

   public Employee(String name, String address, int number) {
      System.out.println("Constructing an Employee");
      this.name = name;
      this.address = address;
      this.number = number;
   }

   public void mailCheck() {
      System.out.println("Mailing a check to " + this.name + " " + this.address);
   }

   public String toString() {
      return name + " " + address + " " + number;
   }

   public String getName() {
      return name;
   }

   public String getAddress() {
      return address;
   }

   public void setAddress(String newAddress) {
      address = newAddress;
   }

   public int getNumber() {
      return number;
   }
}

이제 Employee 클래스를 다음과 같이 확장한다고 가정합니다.

/* File name : Salary.java */
public class Salary extends Employee {
   private double salary; // Annual salary
   
   public Salary(String name, String address, int number, double salary) {
      super(name, address, number);
      setSalary(salary);
   }
   
   public void mailCheck() {
      System.out.println("Within mailCheck of Salary class ");
      System.out.println("Mailing check to " + getName()
      + " with salary " + salary);
   }
   
   public double getSalary() {
      return salary;
   }
   
   public void setSalary(double newSalary) {
      if(newSalary >= 0.0) {
         salary = newSalary;
      }
   }
   
   public double computePay() {
      System.out.println("Computing salary pay for " + getName());
      return salary/52;
   }
}

이제 다음 프로그램을주의 깊게 연구하고 결과를 결정하려고합니다.

/* File name : VirtualDemo.java */
public class VirtualDemo {

   public static void main(String [] args) {
      Salary s = new Salary("Mohd Mohtashim", "Ambehta, UP", 3, 3600.00);
      Employee e = new Salary("John Adams", "Boston, MA", 2, 2400.00);
      System.out.println("Call mailCheck using Salary reference --");   
      s.mailCheck();
      System.out.println("\n Call mailCheck using Employee reference--");
      e.mailCheck();
   }
}

이것은 다음 결과를 생성합니다-

산출

Constructing an Employee
Constructing an Employee

Call mailCheck using Salary reference --
Within mailCheck of Salary class
Mailing check to Mohd Mohtashim with salary 3600.0

Call mailCheck using Employee reference--
Within mailCheck of Salary class
Mailing check to John Adams with salary 2400.0

여기에서 두 개의 Salary 개체를 인스턴스화합니다. 급여 참조를 사용하는 사람s및 직원 참조를 사용하는 다른 e.

s.mailCheck () 를 호출하는 동안 컴파일러는 컴파일 타임에 Salary 클래스에서 mailCheck ()를보고 JVM은 런타임에 Salary 클래스에서 mailCheck ()를 호출합니다.

mailCheck () on e 왜냐하면 e직원 참조입니다. 컴파일러가 e.mailCheck () 를 보면 컴파일러는 Employee 클래스에서 mailCheck () 메서드를 봅니다.

여기서 컴파일 타임에 컴파일러는 Employee의 mailCheck ()를 사용하여이 문을 확인했습니다. 그러나 런타임에 JVM은 Salary 클래스에서 mailCheck ()를 호출합니다.

이 동작을 가상 메서드 호출이라고하며 이러한 메서드를 가상 메서드라고합니다. 재정의 된 메서드는 컴파일 타임에 소스 코드에서 사용 된 참조 데이터 유형에 관계없이 런타임에 호출됩니다.

사전에 따라 abstraction사건보다는 아이디어를 다루는 품질입니다. 예를 들어, 전자 메일의 경우를 고려할 때 전자 메일을 보내 자마자 발생하는 상황과 같은 복잡한 세부 정보는 전자 메일 서버에서 사용하는 프로토콜이 사용자에게 표시되지 않습니다. 따라서 이메일을 보내려면 내용을 입력하고 수신자의 주소를 언급 한 다음 보내기를 클릭하기 만하면됩니다.

객체 지향 프로그래밍과 마찬가지로 추상화는 구현 세부 사항을 사용자에게 숨기는 프로세스이며 기능 만 사용자에게 제공됩니다. 즉, 사용자는 객체가 수행하는 방식 대신 객체가 수행하는 작업에 대한 정보를 갖게됩니다.

Java에서 추상화는 Abstract 클래스와 인터페이스를 사용하여 이루어집니다.

추상 클래스

포함하는 클래스 abstract 선언의 키워드를 추상 클래스라고합니다.

  • 추상 클래스는 추상 메서드를 포함하거나 포함하지 않을 수 있습니다 . 즉, 본문이없는 메서드 (public void get ();)

  • 그러나 클래스에 적어도 하나의 추상 메서드가있는 경우 클래스는 must 초록으로 선언되어야합니다.

  • 클래스가 추상으로 선언되면 인스턴스화 할 수 없습니다.

  • 추상 클래스를 사용하려면 다른 클래스에서 상속하고 그 안에있는 추상 메서드에 대한 구현을 제공해야합니다.

  • 추상 클래스를 상속하는 경우 모든 추상 메서드에 대한 구현을 제공해야합니다.

이 섹션에서는 추상 클래스의 예를 제공합니다. 추상 클래스를 만들려면abstract 클래스 선언에서 클래스 키워드 앞의 키워드.

/* File name : Employee.java */
public abstract class Employee {
   private String name;
   private String address;
   private int number;

   public Employee(String name, String address, int number) {
      System.out.println("Constructing an Employee");
      this.name = name;
      this.address = address;
      this.number = number;
   }
   
   public double computePay() {
     System.out.println("Inside Employee computePay");
     return 0.0;
   }
   
   public void mailCheck() {
      System.out.println("Mailing a check to " + this.name + " " + this.address);
   }

   public String toString() {
      return name + " " + address + " " + number;
   }

   public String getName() {
      return name;
   }
 
   public String getAddress() {
      return address;
   }
   
   public void setAddress(String newAddress) {
      address = newAddress;
   }
 
   public int getNumber() {
      return number;
   }
}

추상 메소드를 제외하고 Employee 클래스는 Java의 일반 클래스와 동일하다는 것을 알 수 있습니다. 클래스는 이제 추상이지만 여전히 3 개의 필드, 7 개의 메서드 및 1 개의 생성자가 있습니다.

이제 다음과 같은 방법으로 Employee 클래스를 인스턴스화 할 수 있습니다.

/* File name : AbstractDemo.java */
public class AbstractDemo {

   public static void main(String [] args) {
      /* Following is not allowed and would raise error */
      Employee e = new Employee("George W.", "Houston, TX", 43);
      System.out.println("\n Call mailCheck using Employee reference--");
      e.mailCheck();
   }
}

위의 클래스를 컴파일하면 다음과 같은 오류가 발생합니다.

Employee.java:46: Employee is abstract; cannot be instantiated
      Employee e = new Employee("George W.", "Houston, TX", 43);
                   ^
1 error

추상 클래스 상속

다음과 같은 방법으로 구체적인 클래스처럼 Employee 클래스의 속성을 상속 할 수 있습니다.

/* File name : Salary.java */
public class Salary extends Employee {
   private double salary;   // Annual salary
   
   public Salary(String name, String address, int number, double salary) {
      super(name, address, number);
      setSalary(salary);
   }
   
   public void mailCheck() {
      System.out.println("Within mailCheck of Salary class ");
      System.out.println("Mailing check to " + getName() + " with salary " + salary);
   }
 
   public double getSalary() {
      return salary;
   }
   
   public void setSalary(double newSalary) {
      if(newSalary >= 0.0) {
         salary = newSalary;
      }
   }
   
   public double computePay() {
      System.out.println("Computing salary pay for " + getName());
      return salary/52;
   }
}

여기서는 Employee 클래스를 인스턴스화 할 수 없지만 Salary 클래스를 인스턴스화 할 수 있으며이 인스턴스를 사용하면 아래와 같이 Employee 클래스의 3 개 필드와 7 개 메서드에 모두 액세스 할 수 있습니다.

/* File name : AbstractDemo.java */
public class AbstractDemo {

   public static void main(String [] args) {
      Salary s = new Salary("Mohd Mohtashim", "Ambehta, UP", 3, 3600.00);
      Employee e = new Salary("John Adams", "Boston, MA", 2, 2400.00);
      System.out.println("Call mailCheck using Salary reference --");
      s.mailCheck();
      System.out.println("\n Call mailCheck using Employee reference--");
      e.mailCheck();
   }
}

이것은 다음 결과를 생성합니다-

산출

Constructing an Employee
Constructing an Employee
Call mailCheck using Salary reference --
Within mailCheck of Salary class 
Mailing check to Mohd Mohtashim with salary 3600.0

 Call mailCheck using Employee reference--
Within mailCheck of Salary class 
Mailing check to John Adams with salary 2400.0

추상 방법

클래스에 특정 메서드를 포함하고 싶지만 해당 메서드의 실제 구현이 자식 클래스에 의해 결정되도록하려면 부모 클래스의 메서드를 추상으로 선언 할 수 있습니다.

  • abstract 키워드는 메서드를 추상으로 선언하는 데 사용됩니다.

  • 당신은 배치해야 abstract 메서드 선언에서 메서드 이름 앞에 키워드.

  • 추상 메서드에는 메서드 서명이 포함되어 있지만 메서드 본문은 없습니다.

  • 중괄호 대신 추상 메서드는 끝에 세모이 콜론 (;)이 있습니다.

다음은 추상 방법의 예입니다.

public abstract class Employee {
   private String name;
   private String address;
   private int number;
   
   public abstract double computePay();
   // Remainder of class definition
}

메서드를 추상으로 선언하면 두 가지 결과가 있습니다.

  • 그것을 포함하는 클래스는 추상으로 선언되어야합니다.

  • 현재 클래스를 상속하는 모든 클래스는 추상 메서드를 재정의하거나 자신을 추상으로 선언해야합니다.

Note-결국, 자손 클래스는 추상 메소드를 구현해야합니다. 그렇지 않으면 인스턴스화 할 수없는 추상 클래스 계층 구조를 갖게됩니다.

Salary 클래스가 Employee 클래스를 상속한다고 가정하면 다음을 구현해야합니다. computePay() 아래와 같이 방법-

/* File name : Salary.java */
public class Salary extends Employee {
   private double salary;   // Annual salary
  
   public double computePay() {
      System.out.println("Computing salary pay for " + getName());
      return salary/52;
   }
   // Remainder of class definition
}

Encapsulation네 가지 기본 OOP 개념 중 하나입니다. 나머지 세 가지는 상속, 다형성 및 추상화입니다.

Java의 캡슐화는 데이터 (변수)와 데이터 (메소드)에 작용하는 코드를 단일 단위로 함께 래핑하는 메커니즘입니다. 캡슐화에서 클래스의 변수는 다른 클래스에서 숨겨지며 현재 클래스의 메서드를 통해서만 액세스 할 수 있습니다. 따라서data hiding.

자바 캡슐화를 달성하려면-

  • 클래스의 변수를 전용으로 선언하십시오.

  • 변수 값을 수정하고 볼 수있는 공용 setter 및 getter 메서드를 제공합니다.

다음은 Java에서 캡슐화를 달성하는 방법을 보여주는 예입니다.

/* File name : EncapTest.java */
public class EncapTest {
   private String name;
   private String idNum;
   private int age;

   public int getAge() {
      return age;
   }

   public String getName() {
      return name;
   }

   public String getIdNum() {
      return idNum;
   }

   public void setAge( int newAge) {
      age = newAge;
   }

   public void setName(String newName) {
      name = newName;
   }

   public void setIdNum( String newId) {
      idNum = newId;
   }
}

공용 setXXX () 및 getXXX () 메서드는 EncapTest 클래스의 인스턴스 변수에 대한 액세스 포인트입니다. 일반적으로 이러한 메서드를 게터 및 세터라고합니다. 따라서 변수에 액세스하려는 모든 클래스는 이러한 getter 및 setter를 통해 변수에 액세스해야합니다.

EncapTest 클래스의 변수는 다음 프로그램을 사용하여 액세스 할 수 있습니다.

/* File name : RunEncap.java */
public class RunEncap {

   public static void main(String args[]) {
      EncapTest encap = new EncapTest();
      encap.setName("James");
      encap.setAge(20);
      encap.setIdNum("12343ms");

      System.out.print("Name : " + encap.getName() + " Age : " + encap.getAge());
   }
}

이것은 다음 결과를 생성합니다-

산출

Name : James Age : 20

캡슐화의 이점

  • 클래스의 필드는 읽기 전용 또는 쓰기 전용으로 만들 수 있습니다.

  • 클래스는 필드에 저장된 내용을 완전히 제어 할 수 있습니다.

인터페이스는 Java의 참조 유형입니다. 클래스와 비슷합니다. 추상적 인 방법의 모음입니다. 클래스는 인터페이스를 구현하여 인터페이스의 추상 메서드를 상속합니다.

추상 메서드와 함께 인터페이스에는 상수, 기본 메서드, 정적 메서드 및 중첩 형식도 포함될 수 있습니다. 메서드 본문은 기본 메서드 및 정적 메서드에 대해서만 존재합니다.

인터페이스 작성은 클래스 작성과 유사합니다. 그러나 클래스는 객체의 속성과 동작을 설명합니다. 그리고 인터페이스에는 클래스가 구현하는 동작이 포함됩니다.

인터페이스를 구현하는 클래스가 추상적 인 경우가 아니면 인터페이스의 모든 메서드를 클래스에 정의해야합니다.

인터페이스는 다음과 같은면에서 클래스와 유사합니다.

  • 인터페이스는 여러 메소드를 포함 할 수 있습니다.

  • 인터페이스는 .java 확장자, 파일 이름과 일치하는 인터페이스 이름

  • 인터페이스의 바이트 코드는 .class 파일.

  • 인터페이스는 패키지에 나타나며 해당 바이트 코드 파일은 패키지 이름과 일치하는 디렉토리 구조에 있어야합니다.

그러나 인터페이스는 다음을 포함하여 여러면에서 클래스와 다릅니다.

  • 인터페이스를 인스턴스화 할 수 없습니다.

  • 인터페이스에는 생성자가 없습니다.

  • 인터페이스의 모든 메소드는 추상적입니다.

  • 인터페이스는 인스턴스 필드를 포함 할 수 없습니다. 인터페이스에 나타날 수있는 유일한 필드는 static 및 final로 선언되어야합니다.

  • 인터페이스는 클래스에 의해 확장되지 않습니다. 클래스에 의해 구현됩니다.

  • 인터페이스는 여러 인터페이스를 확장 할 수 있습니다.

인터페이스 선언

그만큼 interface키워드는 인터페이스를 선언하는 데 사용됩니다. 다음은 인터페이스를 선언하는 간단한 예입니다.

다음은 인터페이스의 예입니다.

/* File name : NameOfInterface.java */
import java.lang.*;
// Any number of import statements

public interface NameOfInterface {
   // Any number of final, static fields
   // Any number of abstract method declarations\
}

인터페이스에는 다음과 같은 속성이 있습니다.

  • 인터페이스는 암시 적으로 추상적입니다. 당신은 사용할 필요가 없습니다abstract 인터페이스를 선언하는 동안 키워드.

  • 인터페이스의 각 메서드는 암시 적으로 추상이므로 abstract 키워드가 필요하지 않습니다.

  • 인터페이스의 메서드는 암시 적으로 공개됩니다.

/* File name : Animal.java */
interface Animal {
   public void eat();
   public void travel();
}

인터페이스 구현

클래스가 인터페이스를 구현할 때 클래스를 계약에 서명하고 인터페이스의 특정 동작을 수행하는 데 동의하는 것으로 생각할 수 있습니다. 클래스가 인터페이스의 모든 동작을 수행하지 않는 경우 클래스는 자신을 추상으로 선언해야합니다.

클래스는 implements인터페이스를 구현하는 키워드입니다. 구현 키워드는 선언의 확장 부분 다음에 나오는 클래스 선언에 나타납니다.

/* File name : MammalInt.java */
public class MammalInt implements Animal {

   public void eat() {
      System.out.println("Mammal eats");
   }

   public void travel() {
      System.out.println("Mammal travels");
   } 

   public int noOfLegs() {
      return 0;
   }

   public static void main(String args[]) {
      MammalInt m = new MammalInt();
      m.eat();
      m.travel();
   }
}

이것은 다음 결과를 생성합니다-

산출

Mammal eats
Mammal travels

인터페이스에 정의 된 메서드를 재정의 할 때 따라야 할 몇 가지 규칙이 있습니다.

  • 확인 된 예외는 인터페이스 메서드에 의해 선언 된 것 이외의 구현 메서드 또는 인터페이스 메서드에 의해 선언 된 서브 클래스에 선언되어서는 안됩니다.

  • 인터페이스 메서드의 서명과 동일한 반환 유형 또는 하위 유형은 메서드를 재정의 할 때 유지되어야합니다.

  • 구현 클래스 자체는 추상적 일 수 있으며 그렇다면 인터페이스 메소드를 구현할 필요가 없습니다.

구현 인터페이스에는 몇 가지 규칙이 있습니다.

  • 클래스는 한 번에 둘 이상의 인터페이스를 구현할 수 있습니다.

  • 클래스는 하나의 클래스 만 확장 할 수 있지만 많은 인터페이스를 구현합니다.

  • 인터페이스는 클래스가 다른 클래스를 확장 할 수있는 것과 유사한 방식으로 다른 인터페이스를 확장 할 수 있습니다.

인터페이스 확장

인터페이스는 클래스가 다른 클래스를 확장 할 수있는 것과 같은 방식으로 다른 인터페이스를 확장 할 수 있습니다. 그만큼extends 키워드는 인터페이스를 확장하는 데 사용되며 자식 인터페이스는 부모 인터페이스의 메서드를 상속합니다.

다음 Sports 인터페이스는 Hockey 및 Football 인터페이스로 확장됩니다.

// Filename: Sports.java
public interface Sports {
   public void setHomeTeam(String name);
   public void setVisitingTeam(String name);
}

// Filename: Football.java
public interface Football extends Sports {
   public void homeTeamScored(int points);
   public void visitingTeamScored(int points);
   public void endOfQuarter(int quarter);
}

// Filename: Hockey.java
public interface Hockey extends Sports {
   public void homeGoalScored();
   public void visitingGoalScored();
   public void endOfPeriod(int period);
   public void overtimePeriod(int ot);
}

Hockey 인터페이스에는 네 가지 메서드가 있지만 Sports에서 두 가지 방법을 상속합니다. 따라서 Hockey를 구현하는 클래스는 6 개의 메서드를 모두 구현해야합니다. 마찬가지로 Football을 구현하는 클래스는 Football의 세 가지 메서드와 Sports의 두 가지 메서드를 정의해야합니다.

여러 인터페이스 확장

Java 클래스는 하나의 상위 클래스 만 확장 할 수 있습니다. 다중 상속은 허용되지 않습니다. 그러나 인터페이스는 클래스가 아니며 인터페이스는 둘 이상의 상위 인터페이스를 확장 할 수 있습니다.

extends 키워드는 한 번 사용되며 상위 인터페이스는 쉼표로 구분 된 목록으로 선언됩니다.

예를 들어, Hockey 인터페이스가 스포츠와 이벤트를 모두 확장하면 다음과 같이 선언됩니다.

public interface Hockey extends Sports, Event

태그 지정 인터페이스

확장 인터페이스의 가장 일반적인 사용은 부모 인터페이스에 메서드가 포함되어 있지 않을 때 발생합니다. 예를 들어, java.awt.event 패키지 확장 java.util.EventListener의 MouseListener 인터페이스는 다음과 같이 정의됩니다.

package java.util;
public interface EventListener
{}

메서드가없는 인터페이스를 tagging상호 작용. 인터페이스 태그 지정에는 두 가지 기본 설계 목적이 있습니다.

Creates a common parent− Java API에서 수십 개의 다른 인터페이스로 확장 된 EventListener 인터페이스와 마찬가지로 태그 인터페이스를 사용하여 인터페이스 그룹간에 공통 부모를 생성 할 수 있습니다. 예를 들어 인터페이스가 EventListener를 확장 할 때 JVM은이 특정 인터페이스가 이벤트 위임 시나리오에서 사용될 것임을 알고 있습니다.

Adds a data type to a class−이 상황은 태깅이라는 용어의 유래입니다. 태깅 인터페이스를 구현하는 클래스는 어떤 메서드도 정의 할 필요가 없지만 (인터페이스에 어떤 메서드도 없기 때문에) 클래스는 다형성을 통해 인터페이스 유형이됩니다.

패키지는 이름 충돌을 방지하고 액세스를 제어하며 클래스, 인터페이스, 열거 및 주석의 검색 / 찾기 및 사용을 더 쉽게 만들기 위해 Java에서 사용됩니다.

Package 액세스 보호 및 네임 스페이스 관리를 제공하는 관련 유형 (클래스, 인터페이스, 열거 및 주석)의 그룹으로 정의 할 수 있습니다.

Java의 기존 패키지 중 일부는-

  • java.lang − 기본 클래스 번들

  • java.io − 입력, 출력 함수에 대한 클래스가이 패키지에 번들로 제공됩니다.

프로그래머는 자신의 패키지를 정의하여 클래스 / 인터페이스 그룹 등을 묶을 수 있습니다. 프로그래머가 클래스, 인터페이스, 열거 및 주석이 관련되어 있는지 쉽게 확인할 수 있도록 사용자가 구현 한 관련 클래스를 그룹화하는 것이 좋습니다.

패키지가 새 네임 스페이스를 생성하므로 다른 패키지의 이름과 충돌하는 이름이 없습니다. 패키지를 사용하면 액세스 제어를 더 쉽게 제공하고 관련 클래스를 더 쉽게 찾을 수 있습니다.

패키지 생성

패키지를 생성하는 동안 패키지 이름을 선택하고 package 패키지에 포함 할 클래스, 인터페이스, 열거 형 및 주석 유형을 포함하는 모든 소스 파일의 맨 위에있는 해당 이름과 함께 명령문.

패키지 명령문은 소스 파일의 첫 번째 행이어야합니다. 각 소스 파일에는 하나의 패키지 문만있을 수 있으며 파일의 모든 유형에 적용됩니다.

패키지 문을 사용하지 않으면 클래스, 인터페이스, 열거 및 주석 유형이 현재 기본 패키지에 배치됩니다.

package 문으로 Java 프로그램을 컴파일하려면 아래와 같이 -d 옵션을 사용해야합니다.

javac -d Destination_folder file_name.java

그런 다음 지정된 패키지 이름을 가진 폴더가 지정된 대상에 생성되고 컴파일 된 클래스 파일이 해당 폴더에 배치됩니다.

다음과 같은 패키지를 생성하는 예를 살펴 보겠습니다. animals. 클래스 및 인터페이스 이름과 충돌하지 않도록 소문자로 된 패키지 이름을 사용하는 것이 좋습니다.

다음 패키지 예는 인터페이스 이름이 포함 동물 -

/* File name : Animal.java */
package animals;

interface Animal {
   public void eat();
   public void travel();
}

이제, 우리는 동일한 패키지에 위의 인터페이스를 구현하자 동물 -

package animals;
/* File name : MammalInt.java */

public class MammalInt implements Animal {

   public void eat() {
      System.out.println("Mammal eats");
   }

   public void travel() {
      System.out.println("Mammal travels");
   } 

   public int noOfLegs() {
      return 0;
   }

   public static void main(String args[]) {
      MammalInt m = new MammalInt();
      m.eat();
      m.travel();
   }
}

이제 아래와 같이 자바 파일을 컴파일하십시오.

$ javac -d . Animal.java $ javac -d . MammalInt.java

이제 이름이있는 패키지 / 폴더 animals 현재 디렉토리에 생성되고이 클래스 파일은 아래와 같이 배치됩니다.

패키지 내에서 클래스 파일을 실행하면 아래와 같은 결과를 얻을 수 있습니다.

Mammal eats
Mammal travels

수입 키워드

클래스가 동일한 패키지에있는 다른 클래스를 사용하려는 경우 패키지 이름을 사용할 필요가 없습니다. 동일한 패키지의 클래스는 특별한 구문없이 서로를 찾습니다.

여기에서 Boss라는 클래스가 이미 Employee가 포함 된 급여 패키지에 추가됩니다. 그런 다음 Boss는 다음 Boss 클래스에서 보여주는 것처럼 급여 접두사를 사용하지 않고 Employee 클래스를 참조 할 수 있습니다.

package payroll;
public class Boss {
   public void payEmployee(Employee e) {
      e.mailCheck();
   }
}

Employee 클래스가 급여 패키지에 없으면 어떻게됩니까? 그런 다음 Boss 클래스는 다른 패키지의 클래스를 참조하기 위해 다음 기술 중 하나를 사용해야합니다.

  • 클래스의 완전한 이름을 사용할 수 있습니다. 예를 들면-
payroll.Employee
  • import 키워드와 와일드 카드 (*)를 사용하여 패키지를 가져올 수 있습니다. 예를 들면-

import payroll.*;
  • import 키워드를 사용하여 클래스 자체를 가져올 수 있습니다. 예를 들면-
import payroll.Employee;

Note− 클래스 파일에는 여러 개의 import 문이 포함될 수 있습니다. import 문은 패키지 문 뒤와 클래스 선언 앞에 나타나야합니다.

패키지의 디렉토리 구조

클래스가 패키지에 배치되면 두 가지 주요 결과가 발생합니다.

  • 패키지 이름은 이전 섹션에서 방금 설명한 것처럼 클래스 이름의 일부가됩니다.

  • 패키지 이름은 해당 바이트 코드가있는 디렉토리 구조와 일치해야합니다.

다음은 Java로 파일을 관리하는 간단한 방법입니다.

클래스, 인터페이스, 열거 또는 주석 유형의 소스 코드를 이름이 유형의 단순 이름이고 확장자가 인 텍스트 파일에 넣으십시오. .java.

예를 들면-

// File Name :  Car.java
package vehicle;

public class Car {
   // Class implementation.   
}

이제 클래스가 속한 패키지의 이름을 반영하는 이름의 디렉토리에 소스 파일을 넣으십시오.

....\vehicle\Car.java

이제 정규화 된 클래스 이름과 경로 이름은 다음과 같습니다.

  • 클래스 명 → vehicle.Car
  • 경로 이름 → vehicle \ Car.java (Windows)

일반적으로 회사는 패키지 이름에 역방향 인터넷 도메인 이름을 사용합니다.

Example− 회사의 인터넷 도메인 이름은 apple.com이고 모든 패키지 이름은 com.apple로 시작합니다. 패키지 이름의 각 구성 요소는 하위 디렉터리에 해당합니다.

Example − 회사에는 Dell.java 소스 파일이 포함 된 com.apple.computers 패키지가 있었으며 다음과 같은 일련의 하위 디렉토리에 포함됩니다.

....\com\apple\computers\Dell.java

컴파일시 컴파일러는 정의 된 각 클래스, 인터페이스 및 열거에 대해 다른 출력 파일을 만듭니다. 출력 파일의 기본 이름은 유형의 이름이고 확장자는.class.

예를 들면-

// File Name: Dell.java
package com.apple.computers;

public class Dell {
}

class Ups {
}

이제 -d 옵션을 사용하여 다음과 같이이 파일을 컴파일하십시오.

$javac -d . Dell.java

파일은 다음과 같이 컴파일됩니다.

.\com\apple\computers\Dell.class
.\com\apple\computers\Ups.class

다음과 같이 \ com \ apple \ computers \에 정의 된 모든 클래스 또는 인터페이스를 가져올 수 있습니다.

import com.apple.computers.*;

.java 소스 파일과 마찬가지로 컴파일 된 .class 파일은 패키지 이름을 반영하는 일련의 디렉토리에 있어야합니다. 그러나 .class 파일의 경로는 .java 소스 파일의 경로와 같을 필요는 없습니다. 다음과 같이 소스 및 클래스 디렉토리를 별도로 정렬 할 수 있습니다.

<path-one>\sources\com\apple\computers\Dell.java

<path-two>\classes\com\apple\computers\Dell.class

이렇게하면 소스를 공개하지 않고 다른 프로그래머에게 classes 디렉토리에 대한 액세스 권한을 부여 할 수 있습니다. 또한 컴파일러와 JVM (Java Virtual Machine)이 프로그램에서 사용하는 모든 유형을 찾을 수 있도록 이러한 방식으로 소스 및 클래스 파일을 관리해야합니다.

클래스 디렉토리의 전체 경로 인 <path-two> \ classes는 클래스 경로라고하며 CLASSPATH 시스템 변수로 설정됩니다. 컴파일러와 JVM 모두 클래스 경로에 패키지 이름을 추가하여 .class 파일에 대한 경로를 구성합니다.

<path-two> \ classes가 클래스 경로이고 패키지 이름이 com.apple.computers라고 말하면 컴파일러와 JVM은 <path-two> \ classes \ com \ apple \ computers에서 .class 파일을 찾습니다.

클래스 경로에는 여러 경로가 포함될 수 있습니다. 여러 경로는 세미콜론 (Windows) 또는 콜론 (Unix)으로 구분해야합니다. 기본적으로 컴파일러와 JVM은 현재 디렉토리와 Java 플랫폼 클래스가 포함 된 JAR 파일을 검색하여 이러한 디렉토리가 자동으로 클래스 경로에 있도록합니다.

CLASSPATH 시스템 변수 설정

현재 CLASSPATH 변수를 표시하려면 Windows 및 UNIX (Bourne 쉘)에서 다음 명령을 사용하십시오.

  • Windows에서 → C : \> CLASSPATH 설정
  • UNIX에서 → % echo $ CLASSPATH

CLASSPATH 변수의 현재 내용을 삭제하려면 −

  • Windows에서 → C : \> set CLASSPATH =
  • UNIX에서 → % unset CLASSPATH; CLASSPATH 내보내기

CLASSPATH 변수를 설정하려면-

  • Windows에서 → CLASSPATH = C : \ users \ jack \ java \ classes 설정
  • UNIX에서 → % CLASSPATH = / home / jack / java / classes; CLASSPATH 내보내기

Java 유틸리티 패키지에서 제공하는 데이터 구조는 매우 강력하며 다양한 기능을 수행합니다. 이러한 데이터 구조는 다음 인터페이스와 클래스로 구성됩니다.

  • Enumeration
  • BitSet
  • Vector
  • Stack
  • Dictionary
  • Hashtable
  • Properties

이러한 모든 클래스는 이제 레거시이며 Java-2는 다음 장에서 설명하는 Collections Framework라는 새로운 프레임 워크를 도입했습니다. −

열거

열거 인터페이스는 그 자체가 데이터 구조는 아니지만 다른 데이터 구조의 맥락에서 매우 중요합니다. Enumeration 인터페이스는 데이터 구조에서 연속 요소를 검색하는 수단을 정의합니다.

예를 들어 Enumeration은 여러 요소를 포함하는 데이터 구조에서 다음 요소를 가져 오는 데 사용되는 nextElement라는 메서드를 정의합니다.

이 인터페이스에 대한 자세한 내용은 The Enumeration을 확인하십시오 .

BitSet

BitSet 클래스는 개별적으로 설정하고 지울 수있는 비트 또는 플래그 그룹을 구현합니다.

이 클래스는 부울 값 세트를 유지해야하는 경우에 매우 유용합니다. 각 값에 비트를 할당하고 적절하게 설정하거나 지 웁니다.

이 클래스에 대한 자세한 내용은 The BitSet를 확인하십시오 .

벡터

Vector 클래스는 새 요소를 수용하기 위해 필요에 따라 확장 할 수 있다는 점을 제외하면 기존 Java 배열과 유사합니다.

배열과 마찬가지로 Vector 객체의 요소는 벡터에 대한 인덱스를 통해 액세스 할 수 있습니다.

Vector 클래스를 사용할 때 좋은 점은 생성시 특정 크기로 설정하는 것에 대해 걱정할 필요가 없다는 것입니다. 필요할 때 자동으로 줄어들고 커집니다.

이 클래스에 대한 자세한 내용은 The Vector를 확인하십시오 .

스택

Stack 클래스는 LIFO (last-in-first-out) 요소 스택을 구현합니다.

스택은 말 그대로 수직 스택으로 생각할 수 있습니다. 새 요소를 추가하면 다른 요소 위에 쌓입니다.

스택에서 요소를 뽑으면 맨 위에서 떨어집니다. 즉, 스택에 마지막으로 추가 한 요소가 가장 먼저 반환되는 요소입니다.

이 클래스에 대한 자세한 내용은 The Stack을 확인하십시오 .

사전

Dictionary 클래스는 키를 값에 매핑하기위한 데이터 구조를 정의하는 추상 클래스입니다.

이것은 정수 인덱스가 아닌 특정 키를 통해 데이터에 액세스하려는 경우에 유용합니다.

Dictionary 클래스는 추상적이므로 특정 구현이 아닌 키 매핑 된 데이터 구조에 대한 프레임 워크 만 제공합니다.

이 클래스에 대한 자세한 내용은 The Dictionary를 확인하십시오 .

해시 테이블

Hashtable 클래스는 사용자 정의 키 구조를 기반으로 데이터를 구성하는 수단을 제공합니다.

예를 들어 주소 목록 해시 테이블에서 사람의 이름이 아닌 우편 번호와 같은 키를 기반으로 데이터를 저장하고 정렬 할 수 있습니다.

해시 테이블과 관련된 키의 구체적인 의미는 해시 테이블의 사용 및 포함 된 데이터에 전적으로 의존합니다.

이 클래스에 대한 자세한 내용은 The Hashtable을 확인하십시오 .

속성

속성은 Hashtable의 하위 클래스입니다. 키가 문자열이고 값도 문자열 인 값 목록을 유지하는 데 사용됩니다.

Properties 클래스는 다른 많은 Java 클래스에서 사용됩니다. 예를 들어, 환경 값을 가져올 때 System.getProperties ()에서 반환하는 개체 유형입니다.

이 클래스에 대한 자세한 내용은 속성을 확인하십시오 .

Java 2 이전에 Java는 다음과 같은 임시 클래스를 제공했습니다. Dictionary, Vector, Stack,Properties개체 그룹을 저장하고 조작합니다. 이 수업은 매우 유용했지만 중앙의 통합 주제가 부족했습니다. 따라서 Vector를 사용한 방식은 Properties를 사용한 방식과 달랐습니다.

컬렉션 프레임 워크는 다음과 같은 여러 목표를 충족하도록 설계되었습니다.

  • 프레임 워크는 고성능이어야했습니다. 기본 컬렉션 (동적 배열, 연결 목록, 트리 및 해시 테이블)에 대한 구현은 매우 효율적이었습니다.

  • 프레임 워크는 서로 다른 유형의 컬렉션이 유사한 방식으로 높은 수준의 상호 운용성으로 작동하도록 허용해야했습니다.

  • 프레임 워크는 컬렉션을 쉽게 확장 및 / 또는 조정해야했습니다.

이를 위해 전체 컬렉션 프레임 워크는 일련의 표준 인터페이스를 중심으로 설계되었습니다. 다음과 같은 몇 가지 표준 구현LinkedList, HashSet,TreeSet, 이러한 인터페이스는 그대로 사용할 수 있도록 제공되며 원하는 경우 자체 컬렉션을 구현할 수도 있습니다.

컬렉션 프레임 워크는 컬렉션을 표현하고 조작하기위한 통합 아키텍처입니다. 모든 컬렉션 프레임 워크에는 다음이 포함됩니다.

  • Interfaces− 컬렉션을 나타내는 추상 데이터 유형입니다. 인터페이스를 사용하면 컬렉션을 표현의 세부 사항과 독립적으로 조작 할 수 있습니다. 객체 지향 언어에서 인터페이스는 일반적으로 계층 구조를 형성합니다.

  • Implementations, i.e., Classes− 다음은 컬렉션 인터페이스의 구체적인 구현입니다. 본질적으로 재사용 가능한 데이터 구조입니다.

  • Algorithms− 컬렉션 인터페이스를 구현하는 객체에 대해 검색 및 정렬과 같은 유용한 계산을 수행하는 방법입니다. 알고리즘은 다형성이라고합니다. 즉, 적절한 컬렉션 인터페이스의 여러 다른 구현에서 동일한 메서드를 사용할 수 있습니다.

컬렉션 외에도 프레임 워크는 여러 맵 인터페이스 및 클래스를 정의합니다. 지도는 키 / 값 쌍을 저장합니다. 지도는 용어의 적절한 사용에서 컬렉션 이 아니지만 컬렉션 과 완전히 통합됩니다.

컬렉션 인터페이스

컬렉션 프레임 워크는 여러 인터페이스를 정의합니다. 이 섹션에서는 각 인터페이스에 대한 개요를 제공합니다.

Sr. 아니. 인터페이스 및 설명
1 컬렉션 인터페이스

이를 통해 개체 그룹으로 작업 할 수 있습니다. 컬렉션 계층의 맨 위에 있습니다.

2 목록 인터페이스

이것은 확장 Collection List의 인스턴스는 정렬 된 요소 컬렉션을 저장합니다.

세트

이렇게하면 고유 요소를 포함해야하는 집합을 처리하도록 Collection이 확장됩니다.

4 SortedSet

이것은 정렬 된 세트를 처리하도록 Set를 확장합니다.

5 지도

이것은 고유 한 키를 값에 매핑합니다.

6 The Map.Entry

이것은 맵의 요소 (키 / 값 쌍)를 설명합니다. 이것은 Map의 내부 클래스입니다.

7 SortedMap

이렇게하면 키가 오름차순으로 유지되도록 Map이 확장됩니다.

8 열거

레거시 인터페이스는 개체 컬렉션의 요소를 열거 (한 번에 하나씩 가져옴) 할 수있는 방법을 정의합니다. 이 레거시 인터페이스는 Iterator로 대체되었습니다.

컬렉션 클래스

Java는 Collection 인터페이스를 구현하는 표준 컬렉션 클래스 집합을 제공합니다. 일부 클래스는있는 그대로 사용할 수있는 전체 구현을 제공하고 다른 클래스는 추상 클래스로, 구체적인 컬렉션을 만들기위한 시작점으로 사용되는 골격 구현을 제공합니다.

표준 컬렉션 클래스는 다음 표에 요약되어 있습니다.

Sr. 아니. 클래스 및 설명
1

AbstractCollection

대부분의 Collection 인터페이스를 구현합니다.

2

AbstractList

AbstractCollection을 확장하고 대부분의 List 인터페이스를 구현합니다.

AbstractSequentialList

요소의 임의 액세스가 아닌 순차를 사용하는 컬렉션에서 사용할 수 있도록 AbstractList를 확장합니다.

4 LinkedList

AbstractSequentialList를 확장하여 연결 목록을 구현합니다.

5 ArrayList

AbstractList를 확장하여 동적 배열을 구현합니다.

6

AbstractSet

AbstractCollection을 확장하고 대부분의 Set 인터페이스를 구현합니다.

7 HashSet

해시 테이블과 함께 사용하기 위해 AbstractSet을 확장합니다.

8 LinkedHashSet

삽입 순서 반복을 허용하도록 HashSet을 확장합니다.

9 TreeSet

트리에 저장된 집합을 구현합니다. AbstractSet을 확장합니다.

10

AbstractMap

대부분의 Map 인터페이스를 구현합니다.

11 HashMap

해시 테이블을 사용하도록 AbstractMap을 확장합니다.

12 TreeMap

트리를 사용하도록 AbstractMap을 확장합니다.

13 WeakHashMap

약한 키가있는 해시 테이블을 사용하도록 AbstractMap을 확장합니다.

14 LinkedHashMap

삽입 순서 반복을 허용하도록 HashMap을 확장합니다.

15 IdentityHashMap

AbstractMap을 확장하고 문서를 비교할 때 참조 동등성을 사용합니다.

클래스 AbstractCollection, AbstractSet, AbstractList를, 아니고 AbstractSequentialListAbstractMap 클래스는 노력을 최소화하기을 구현하는 데 필요한 핵심 컬렉션 인터페이스의 스켈 리턴 구현을 제공합니다.

java.util에 의해 정의 된 다음 레거시 클래스는 이전 장에서 논의되었습니다.

Sr. 아니. 클래스 및 설명
1 벡터

이것은 동적 배열을 구현합니다. ArrayList와 비슷하지만 약간의 차이점이 있습니다.

2 스택

Stack은 표준 후입 선출 스택을 구현하는 Vector의 하위 클래스입니다.

사전

Dictionary는 키 / 값 저장소 저장소를 나타내는 추상 클래스이며 Map과 매우 유사하게 작동합니다.

4 해시 테이블

Hashtable은 원래 java.util의 일부였으며 Dictionary의 구체적인 구현입니다.

5 속성

속성은 Hashtable의 하위 클래스입니다. 키가 문자열이고 값도 문자열 인 값 목록을 유지하는 데 사용됩니다.

6 BitSet

BitSet 클래스는 비트 값을 보유하는 특수한 유형의 배열을 만듭니다. 이 어레이는 필요에 따라 크기를 늘릴 수 있습니다.

수집 알고리즘

컬렉션 프레임 워크는 컬렉션 및지도에 적용 할 수있는 여러 알고리즘을 정의합니다. 이러한 알고리즘은 Collections 클래스 내에서 정적 메서드로 정의됩니다.

몇 가지 방법은 ClassCastException, 호환되지 않는 유형을 비교하려고 할 때 발생합니다. UnsupportedOperationException, 수정할 수없는 컬렉션을 수정하려고 할 때 발생합니다.

컬렉션은 EMPTY_SET, EMPTY_LIST 및 EMPTY_MAP의 세 가지 정적 변수를 정의합니다. 모두 불변입니다.

Sr. 아니. 알고리즘 및 설명
1 수집 알고리즘

다음은 모든 알고리즘 구현 목록입니다.

반복자를 사용하는 방법?

종종 컬렉션의 요소를 순환하고 싶을 것입니다. 예를 들어, 각 요소를 표시 할 수 있습니다.

이를 수행하는 가장 쉬운 방법은 Iterator 또는 ListIterator 인터페이스를 구현하는 객체 인 반복기를 사용하는 것입니다.

반복자를 사용하면 컬렉션을 순환하고 요소를 가져 오거나 제거 할 수 있습니다. ListIterator는 Iterator를 확장하여 목록의 양방향 순회 및 요소 수정을 허용합니다.

Sr. 아니. 반복기 방법 및 설명
1 Java Iterator 사용

다음은 Iterator 및 ListIterator 인터페이스에서 제공하는 예제와 함께 모든 메서드 목록입니다.

비교기를 사용하는 방법?

TreeSet과 TreeMap은 모두 정렬 된 순서로 요소를 저장합니다. 그러나 정렬 된 순서의 의미를 정확하게 정의하는 것은 비교기입니다 .

이 인터페이스를 사용하면 주어진 컬렉션을 여러 가지 방법으로 정렬 할 수 있습니다. 또한이 인터페이스를 사용하여 모든 클래스의 인스턴스를 정렬 할 수 있습니다 (수정할 수없는 클래스도 포함).

Sr. 아니. 반복기 방법 및 설명
1 자바 비교기 사용

다음은 Comparator Interface에서 제공하는 예제와 함께 모든 메소드 목록입니다.

요약

Java 컬렉션 프레임 워크는 프로그래머에게 미리 패키지화 된 데이터 구조와이를 조작하기위한 알고리즘에 대한 액세스를 제공합니다.

컬렉션은 다른 개체에 대한 참조를 보유 할 수있는 개체입니다. 컬렉션 인터페이스는 각 컬렉션 유형에서 수행 할 수있는 작업을 선언합니다.

컬렉션 프레임 워크의 클래스와 인터페이스는 java.util 패키지에 있습니다.

Integer 배열, String 배열 또는 정렬을 지원하는 모든 유형의 배열에서 요소를 정렬 할 수있는 단일 정렬 메서드를 작성할 수 있다면 좋을 것입니다.

자바 Generic 메서드 및 제네릭 클래스를 사용하면 프로그래머는 단일 메서드 선언, 관련 메서드 집합 또는 단일 클래스 선언을 사용하여 관련 유형 집합을 각각 지정할 수 있습니다.

제네릭은 또한 프로그래머가 컴파일 타임에 유효하지 않은 형식을 포착 할 수 있도록 컴파일 타임 형식 안전성을 제공합니다.

Java Generic 개념을 사용하여 객체 배열을 정렬하는 일반 메소드를 작성한 다음 Integer 배열, Double 배열, String 배열 등으로 일반 메소드를 호출하여 배열 요소를 정렬 할 수 있습니다.

일반 방법

다른 유형의 인수로 호출 할 수있는 단일 제네릭 메서드 선언을 작성할 수 있습니다. 제네릭 메서드에 전달 된 인수 유형에 따라 컴파일러는 각 메서드 호출을 적절하게 처리합니다. 다음은 일반 방법을 정의하는 규칙입니다-

  • 모든 제네릭 메서드 선언에는 메서드의 반환 형식 앞에 꺾쇠 괄호 (<및>)로 구분 된 형식 매개 변수 섹션이 있습니다 (다음 예제에서는 <E>).

  • 각 유형 매개 변수 섹션에는 쉼표로 구분 된 하나 이상의 유형 매개 변수가 있습니다. 유형 변수라고도하는 유형 매개 변수는 일반 유형 이름을 지정하는 식별자입니다.

  • 형식 매개 변수를 사용하여 반환 형식을 선언하고 실제 형식 인수라고하는 제네릭 메서드에 전달 된 인수 형식에 대한 자리 표시 자 역할을 할 수 있습니다.

  • 제네릭 메서드의 본문은 다른 메서드와 마찬가지로 선언됩니다. 유형 매개 변수는 기본 유형 (예 : int, double 및 char)이 아닌 참조 유형 만 나타낼 수 있습니다.

다음 예제는 단일 Generic 메서드를 사용하여 다른 유형의 배열을 인쇄하는 방법을 보여줍니다.

public class GenericMethodTest {
   // generic method printArray
   public static < E > void printArray( E[] inputArray ) {
      // Display array elements
      for(E element : inputArray) {
         System.out.printf("%s ", element);
      }
      System.out.println();
   }

   public static void main(String args[]) {
      // Create arrays of Integer, Double and Character
      Integer[] intArray = { 1, 2, 3, 4, 5 };
      Double[] doubleArray = { 1.1, 2.2, 3.3, 4.4 };
      Character[] charArray = { 'H', 'E', 'L', 'L', 'O' };

      System.out.println("Array integerArray contains:");
      printArray(intArray);   // pass an Integer array

      System.out.println("\nArray doubleArray contains:");
      printArray(doubleArray);   // pass a Double array

      System.out.println("\nArray characterArray contains:");
      printArray(charArray);   // pass a Character array
   }
}

이것은 다음 결과를 생성합니다-

산출

Array integerArray contains:
1 2 3 4 5 

Array doubleArray contains:
1.1 2.2 3.3 4.4 

Array characterArray contains:
H E L L O

경계 유형 매개 변수

유형 매개 변수에 전달할 수있는 유형의 종류를 제한하려는 경우가있을 수 있습니다. 예를 들어 숫자에 대해 작동하는 메서드는 Number 또는 해당 하위 클래스의 인스턴스 만 허용하려고 할 수 있습니다. 이것이 경계 유형 매개 변수의 용도입니다.

경계 유형 매개 변수를 선언하려면 유형 매개 변수의 이름, extends 키워드, 상위 경계를 차례로 나열하십시오.

다음 예제는 "extends"(클래스에서와 같이) 또는 "implements"(인터페이스에서와 같이)를 의미하는 일반적인 의미에서 extends가 사용되는 방법을 보여줍니다. 이 예제는 세 개의 Comparable 객체 중 가장 큰 것을 반환하는 Generic 메서드입니다.

public class MaximumTest {
   // determines the largest of three Comparable objects
   
   public static <T extends Comparable<T>> T maximum(T x, T y, T z) {
      T max = x;   // assume x is initially the largest
      
      if(y.compareTo(max) > 0) {
         max = y;   // y is the largest so far
      }
      
      if(z.compareTo(max) > 0) {
         max = z;   // z is the largest now                 
      }
      return max;   // returns the largest object   
   }
   
   public static void main(String args[]) {
      System.out.printf("Max of %d, %d and %d is %d\n\n", 
         3, 4, 5, maximum( 3, 4, 5 ));

      System.out.printf("Max of %.1f,%.1f and %.1f is %.1f\n\n",
         6.6, 8.8, 7.7, maximum( 6.6, 8.8, 7.7 ));

      System.out.printf("Max of %s, %s and %s is %s\n","pear",
         "apple", "orange", maximum("pear", "apple", "orange"));
   }
}

이것은 다음 결과를 생성합니다-

산출

Max of 3, 4 and 5 is 5

Max of 6.6,8.8 and 7.7 is 8.8

Max of pear, apple and orange is pear

일반 클래스

제네릭 클래스 선언은 클래스 이름 뒤에 형식 매개 변수 섹션이 오는 것을 제외하고는 제네릭이 아닌 클래스 선언과 비슷합니다.

제네릭 메서드와 마찬가지로 제네릭 클래스의 형식 매개 변수 섹션에는 쉼표로 구분 된 하나 이상의 형식 매개 변수가있을 수 있습니다. 이러한 클래스는 하나 이상의 매개 변수를 허용하므로 매개 변수화 된 클래스 또는 매개 변수화 된 유형이라고합니다.

다음 예제는 일반 클래스를 정의하는 방법을 보여줍니다.

public class Box<T> {
   private T t;

   public void add(T t) {
      this.t = t;
   }

   public T get() {
      return t;
   }

   public static void main(String[] args) {
      Box<Integer> integerBox = new Box<Integer>();
      Box<String> stringBox = new Box<String>();
    
      integerBox.add(new Integer(10));
      stringBox.add(new String("Hello World"));

      System.out.printf("Integer Value :%d\n\n", integerBox.get());
      System.out.printf("String Value :%s\n", stringBox.get());
   }
}

이것은 다음 결과를 생성합니다-

산출

Integer Value :10
String Value :Hello World

Java는 객체 직렬화라는 메커니즘을 제공합니다. 여기서 객체는 객체의 데이터는 물론 객체의 유형 및 객체에 저장된 데이터 유형에 대한 정보를 포함하는 바이트 시퀀스로 나타낼 수 있습니다.

직렬화 된 객체가 파일에 기록 된 후에는 파일에서 읽고 직렬화 해제 할 수 있습니다. 즉, 객체와 해당 데이터를 나타내는 유형 정보와 바이트를 사용하여 메모리에서 객체를 다시 만들 수 있습니다.

가장 인상적인 것은 전체 프로세스가 JVM에 독립적이라는 것입니다. 즉, 하나의 플랫폼에서 객체를 직렬화하고 완전히 다른 플랫폼에서 역 직렬화 할 수 있습니다.

클래스 ObjectInputStreamObjectOutputStream 개체를 직렬화 및 역 직렬화하는 메서드가 포함 된 고수준 스트림입니다.

ObjectOutputStream 클래스에는 다양한 데이터 유형을 작성하기위한 많은 쓰기 메서드가 포함되어 있지만 특히 한 가지 방법이 두드러집니다.

public final void writeObject(Object x) throws IOException

위의 메서드는 Object를 직렬화하여 출력 스트림으로 보냅니다. 유사하게, ObjectInputStream 클래스는 객체를 역 직렬화하기위한 다음 메소드를 포함합니다-

public final Object readObject() throws IOException, ClassNotFoundException

이 메서드는 스트림에서 다음 Object를 검색하고 역 직렬화합니다. 반환 값은 Object이므로 적절한 데이터 유형으로 캐스트해야합니다.

Java에서 직렬화가 작동하는 방식을 보여주기 위해 책의 앞부분에서 논의한 Employee 클래스를 사용하겠습니다. Serializable 인터페이스를 구현하는 다음 Employee 클래스가 있다고 가정합니다.

public class Employee implements java.io.Serializable {
   public String name;
   public String address;
   public transient int SSN;
   public int number;
   
   public void mailCheck() {
      System.out.println("Mailing a check to " + name + " " + address);
   }
}

클래스가 성공적으로 직렬화 되려면 두 가지 조건이 충족되어야합니다.

  • 클래스는 java.io.Serializable 인터페이스를 구현해야합니다.

  • 클래스의 모든 필드는 직렬화 가능해야합니다. 필드를 직렬화 할 수없는 경우 표시해야합니다.transient.

Java Standard Class가 직렬화 가능한지 여부를 알고 싶다면 해당 클래스에 대한 설명서를 확인하십시오. 테스트는 간단합니다. 클래스가 java.io.Serializable을 구현하면 직렬화 가능합니다. 그렇지 않으면 그렇지 않습니다.

객체 직렬화

ObjectOutputStream 클래스는 Object를 직렬화하는 데 사용됩니다. 다음 SerializeDemo 프로그램은 Employee 개체를 인스턴스화하고 파일로 직렬화합니다.

프로그램 실행이 완료되면 employee.ser라는 파일이 생성됩니다. 프로그램은 출력을 생성하지 않지만 코드를 연구하고 프로그램이 수행하는 작업을 확인합니다.

Note − 객체를 파일로 직렬화 할 때 Java의 표준 규칙은 파일에 .ser 신장.

import java.io.*;
public class SerializeDemo {

   public static void main(String [] args) {
      Employee e = new Employee();
      e.name = "Reyan Ali";
      e.address = "Phokka Kuan, Ambehta Peer";
      e.SSN = 11122333;
      e.number = 101;
      
      try {
         FileOutputStream fileOut =
         new FileOutputStream("/tmp/employee.ser");
         ObjectOutputStream out = new ObjectOutputStream(fileOut);
         out.writeObject(e);
         out.close();
         fileOut.close();
         System.out.printf("Serialized data is saved in /tmp/employee.ser");
      } catch (IOException i) {
         i.printStackTrace();
      }
   }
}

개체 역 직렬화

다음 DeserializeDemo 프로그램은 SerializeDemo 프로그램에서 만든 Employee 개체를 deserialize합니다. 프로그램을 연구하고 그 결과를 결정하십시오-

import java.io.*;
public class DeserializeDemo {

   public static void main(String [] args) {
      Employee e = null;
      try {
         FileInputStream fileIn = new FileInputStream("/tmp/employee.ser");
         ObjectInputStream in = new ObjectInputStream(fileIn);
         e = (Employee) in.readObject();
         in.close();
         fileIn.close();
      } catch (IOException i) {
         i.printStackTrace();
         return;
      } catch (ClassNotFoundException c) {
         System.out.println("Employee class not found");
         c.printStackTrace();
         return;
      }
      
      System.out.println("Deserialized Employee...");
      System.out.println("Name: " + e.name);
      System.out.println("Address: " + e.address);
      System.out.println("SSN: " + e.SSN);
      System.out.println("Number: " + e.number);
   }
}

이것은 다음 결과를 생성합니다-

산출

Deserialized Employee...
Name: Reyan Ali
Address:Phokka Kuan, Ambehta Peer
SSN: 0
Number:101

다음은 주목해야 할 중요한 사항입니다.

  • try / catch 블록은 readObject () 메서드에 의해 선언 된 ClassNotFoundException을 포착하려고합니다. JVM이 객체를 역 직렬화 할 수 있으려면 클래스의 바이트 코드를 찾을 수 있어야합니다. JVM이 객체의 직렬화 해제 중에 클래스를 찾을 수 없으면 ClassNotFoundException이 발생합니다.

  • readObject ()의 반환 값은 Employee 참조로 캐스팅됩니다.

  • SSN 필드의 값은 객체가 직렬화되었을 때 11122333 이었지만 필드가 일시적이기 때문에이 값은 출력 스트림으로 전송되지 않았습니다. deserialized Employee 개체의 SSN 필드는 0입니다.

네트워크 프로그래밍 이라는 용어 는 여러 장치 (컴퓨터)에서 실행되는 프로그램을 작성하는 것을 의미하며, 여기서 장치는 모두 네트워크를 사용하여 서로 연결됩니다.

J2SE API의 java.net 패키지에는 저수준 통신 세부 정보를 제공하는 클래스 및 인터페이스 모음이 포함되어있어 당면한 문제 해결에 초점을 맞춘 프로그램을 작성할 수 있습니다.

java.net 패키지는 두 가지 공통 네트워크 프로토콜을 지원합니다.

  • TCP− TCP는 전송 제어 프로토콜 (Transmission Control Protocol)을 나타내며 두 ​​애플리케이션 간의 안정적인 통신을 허용합니다. TCP는 일반적으로 TCP / IP라고하는 인터넷 프로토콜을 통해 사용됩니다.

  • UDP − UDP는 응용 프로그램간에 데이터 패킷을 전송할 수있는 비 연결형 프로토콜 인 사용자 데이터 그램 프로토콜을 의미합니다.

이 장에서는 다음 두 주제에 대해 잘 이해하고 있습니다.

  • Socket Programming − 이것은 네트워킹에서 가장 널리 사용되는 개념이며 매우 자세하게 설명되었습니다.

  • URL Processing− 이것은 별도로 다룹니다. Java 언어의 URL 처리 에 대해 알아 보려면 여기를 클릭하십시오 .

소켓 프로그래밍

소켓은 TCP를 사용하는 두 컴퓨터 간의 통신 메커니즘을 제공합니다. 클라이언트 프로그램은 통신 끝에 소켓을 만들고 해당 소켓을 서버에 연결하려고합니다.

연결이 이루어지면 서버는 통신 끝에 소켓 개체를 만듭니다. 클라이언트와 서버는 이제 소켓에 쓰고 읽음으로써 통신 할 수 있습니다.

java.net.Socket 클래스는 소켓을 나타내고, java.net.ServerSocket 클래스는 서버 프로그램이 클라이언트를 수신하고 클라이언트와 연결을 설정하는 메커니즘을 제공합니다.

다음 단계는 소켓을 사용하여 두 컴퓨터간에 TCP 연결을 설정할 때 발생합니다.

  • 서버는 ServerSocket 개체를 인스턴스화하여 통신이 발생할 포트 번호를 나타냅니다.

  • 서버는 ServerSocket 클래스의 accept () 메소드를 호출합니다. 이 메서드는 클라이언트가 주어진 포트에서 서버에 연결할 때까지 기다립니다.

  • 서버가 대기 한 후 클라이언트는 연결할 서버 이름과 포트 번호를 지정하여 Socket 개체를 인스턴스화합니다.

  • Socket 클래스의 생성자는 클라이언트를 지정된 서버와 포트 번호에 연결하려고합니다. 통신이 설정되면 클라이언트는 이제 서버와 통신 할 수있는 Socket 개체를 갖게됩니다.

  • 서버 측에서 accept () 메서드는 클라이언트 소켓에 연결된 서버의 새 소켓에 대한 참조를 반환합니다.

연결이 설정되면 I / O 스트림을 사용하여 통신 할 수 있습니다. 각 소켓에는 OutputStream과 InputStream이 모두 있습니다. 클라이언트의 OutputStream은 서버의 InputStream에 연결되고 클라이언트의 InputStream은 서버의 OutputStream에 연결됩니다.

TCP는 양방향 통신 프로토콜이므로 두 스트림을 통해 동시에 데이터를 전송할 수 있습니다. 다음은 소켓을 구현하는 완전한 메소드 세트를 제공하는 유용한 클래스입니다.

ServerSocket 클래스 메서드

그만큼 java.net.ServerSocket 클래스는 서버 응용 프로그램에서 포트를 얻고 클라이언트 요청을 수신하는 데 사용됩니다.

ServerSocket 클래스에는 4 개의 생성자가 있습니다.

Sr. 아니. 방법 및 설명
1

public ServerSocket(int port) throws IOException

지정된 포트에 바인딩 된 서버 소켓을 만들려고합니다. 포트가 이미 다른 애플리케이션에 의해 바인드 된 경우 예외가 발생합니다.

2

public ServerSocket(int port, int backlog) throws IOException

이전 생성자와 유사하게 backlog 매개 변수는 대기 큐에 저장할 수신 클라이언트 수를 지정합니다.

public ServerSocket(int port, int backlog, InetAddress address) throws IOException

이전 생성자와 마찬가지로 InetAddress 매개 변수는 바인딩 할 로컬 IP 주소를 지정합니다. InetAddress는 여러 IP 주소를 가질 수있는 서버에 사용되므로 서버에서 클라이언트 요청을 수락 할 IP 주소를 지정할 수 있습니다.

4

public ServerSocket() throws IOException

바인딩되지 않은 서버 소켓을 만듭니다. 이 생성자를 사용할 때 서버 소켓을 바인딩 할 준비가되면 bind () 메서드를 사용하십시오.

ServerSocket 생성자가 예외를 throw하지 않으면 애플리케이션이 지정된 포트에 성공적으로 바인딩되었고 클라이언트 요청을받을 준비가되었음을 의미합니다.

다음은 ServerSocket 클래스의 일반적인 방법 중 일부입니다-

Sr. 아니. 방법 및 설명
1

public int getLocalPort()

서버 소켓이 수신하는 포트를 반환합니다. 이 메서드는 생성자에서 포트 번호로 0을 전달하고 서버가 포트를 찾도록하는 경우에 유용합니다.

2

public Socket accept() throws IOException

들어오는 클라이언트를 기다립니다. 이 메서드는 클라이언트가 지정된 포트에서 서버에 연결하거나 소켓이 시간 초과 될 때까지 차단되며, setSoTimeout () 메서드를 사용하여 시간 초과 값이 설정되었다고 가정합니다. 그렇지 않으면이 메서드는 무기한 차단됩니다.

public void setSoTimeout(int timeout)

accept () 동안 서버 소켓이 클라이언트를 기다리는 시간 제한 값을 설정합니다.

4

public void bind(SocketAddress host, int backlog)

소켓을 SocketAddress 개체의 지정된 서버 및 포트에 바인딩합니다. 인수가없는 생성자를 사용하여 ServerSocket을 인스턴스화 한 경우이 메서드를 사용합니다.

ServerSocket이 accept ()를 호출 할 때 메서드는 클라이언트가 연결될 때까지 반환되지 않습니다. 클라이언트가 연결되면 ServerSocket은 지정되지 않은 포트에 새 소켓을 만들고이 새 소켓에 대한 참조를 반환합니다. 이제 클라이언트와 서버간에 TCP 연결이 존재하며 통신을 시작할 수 있습니다.

소켓 클래스 메서드

그만큼 java.net.Socket클래스는 클라이언트와 서버가 서로 통신하는 데 사용하는 소켓을 나타냅니다. 클라이언트는 하나를 인스턴스화하여 Socket 객체를 얻는 반면, 서버는 accept () 메서드의 반환 값에서 Socket 객체를 얻습니다.

Socket 클래스에는 클라이언트가 서버에 연결하는 데 사용하는 5 개의 생성자가 있습니다.

Sr. 아니. 방법 및 설명
1

public Socket(String host, int port) throws UnknownHostException, IOException.

이 방법은 지정된 포트에서 지정된 서버에 연결을 시도합니다. 이 생성자가 예외를 throw하지 않으면 연결이 성공하고 클라이언트가 서버에 연결됩니다.

2

public Socket(InetAddress host, int port) throws IOException

이 메서드는 호스트가 InetAddress 개체로 표시된다는 점을 제외하면 이전 생성자와 동일합니다.

public Socket(String host, int port, InetAddress localAddress, int localPort) throws IOException.

지정된 호스트 및 포트에 연결하여 지정된 주소 및 포트의 로컬 호스트에 소켓을 만듭니다.

4

public Socket(InetAddress host, int port, InetAddress localAddress, int localPort) throws IOException.

이 메서드는 호스트가 String 대신 InetAddress 개체로 표시된다는 점을 제외하면 이전 생성자와 동일합니다.

5

public Socket()

연결되지 않은 소켓을 만듭니다. connect () 메서드를 사용하여이 소켓을 서버에 연결합니다.

Socket 생성자가 반환되면 단순히 Socket 객체를 인스턴스화하는 것이 아니라 실제로 지정된 서버 및 포트에 연결을 시도합니다.

Socket 클래스와 관련된 몇 가지 방법이 여기에 나열되어 있습니다. 클라이언트와 서버에는 모두 Socket 개체가 있으므로 이러한 메서드는 클라이언트와 서버 모두에서 호출 할 수 있습니다.

Sr. 아니. 방법 및 설명
1

public void connect(SocketAddress host, int timeout) throws IOException

이 메서드는 소켓을 지정된 호스트에 연결합니다. 이 메서드는 인수없는 생성자를 사용하여 Socket을 인스턴스화하는 경우에만 필요합니다.

2

public InetAddress getInetAddress()

이 메서드는이 소켓이 연결된 다른 컴퓨터의 주소를 반환합니다.

public int getPort()

원격 시스템에서 소켓이 바인딩 된 포트를 반환합니다.

4

public int getLocalPort()

소켓이 로컬 시스템에서 바인딩 된 포트를 반환합니다.

5

public SocketAddress getRemoteSocketAddress()

원격 소켓의 주소를 반환합니다.

6

public InputStream getInputStream() throws IOException

소켓의 입력 스트림을 반환합니다. 입력 스트림은 원격 소켓의 출력 스트림에 연결됩니다.

7

public OutputStream getOutputStream() throws IOException

소켓의 출력 스트림을 반환합니다. 출력 스트림은 원격 소켓의 입력 스트림에 연결됩니다.

8

public void close() throws IOException

소켓을 닫으면이 Socket 객체가 더 이상 서버에 다시 연결할 수 없습니다.

InetAddress 클래스 메서드

이 클래스는 인터넷 프로토콜 (IP) 주소를 나타냅니다. 다음은 소켓 프로그래밍을하는 동안 필요한 유용한 방법입니다.

Sr. 아니. 방법 및 설명
1

static InetAddress getByAddress(byte[] addr)

원시 IP 주소가 지정된 InetAddress 개체를 반환합니다.

2

static InetAddress getByAddress(String host, byte[] addr)

제공된 호스트 이름 및 IP 주소를 기반으로 InetAddress를 만듭니다.

static InetAddress getByName(String host)

호스트 이름이 주어지면 호스트의 IP 주소를 결정합니다.

4

String getHostAddress()

텍스트 표현으로 IP 주소 문자열을 반환합니다.

5

String getHostName()

이 IP 주소의 호스트 이름을 가져옵니다.

6

static InetAddress InetAddress getLocalHost()

로컬 호스트를 반환합니다.

7

String toString()

이 IP 주소를 문자열로 변환합니다.

소켓 클라이언트 예

다음 GreetingClient는 소켓을 사용하여 서버에 연결하여 인사말을 보낸 다음 응답을 기다리는 클라이언트 프로그램입니다.

// File Name GreetingClient.java
import java.net.*;
import java.io.*;

public class GreetingClient {

   public static void main(String [] args) {
      String serverName = args[0];
      int port = Integer.parseInt(args[1]);
      try {
         System.out.println("Connecting to " + serverName + " on port " + port);
         Socket client = new Socket(serverName, port);
         
         System.out.println("Just connected to " + client.getRemoteSocketAddress());
         OutputStream outToServer = client.getOutputStream();
         DataOutputStream out = new DataOutputStream(outToServer);
         
         out.writeUTF("Hello from " + client.getLocalSocketAddress());
         InputStream inFromServer = client.getInputStream();
         DataInputStream in = new DataInputStream(inFromServer);
         
         System.out.println("Server says " + in.readUTF());
         client.close();
      } catch (IOException e) {
         e.printStackTrace();
      }
   }
}

소켓 서버 예

다음 GreetingServer 프로그램은 Socket 클래스를 사용하여 명령 줄 인수로 지정된 포트 번호에서 클라이언트를 수신하는 서버 응용 프로그램의 예입니다.

// File Name GreetingServer.java
import java.net.*;
import java.io.*;

public class GreetingServer extends Thread {
   private ServerSocket serverSocket;
   
   public GreetingServer(int port) throws IOException {
      serverSocket = new ServerSocket(port);
      serverSocket.setSoTimeout(10000);
   }

   public void run() {
      while(true) {
         try {
            System.out.println("Waiting for client on port " + 
               serverSocket.getLocalPort() + "...");
            Socket server = serverSocket.accept();
            
            System.out.println("Just connected to " + server.getRemoteSocketAddress());
            DataInputStream in = new DataInputStream(server.getInputStream());
            
            System.out.println(in.readUTF());
            DataOutputStream out = new DataOutputStream(server.getOutputStream());
            out.writeUTF("Thank you for connecting to " + server.getLocalSocketAddress()
               + "\nGoodbye!");
            server.close();
            
         } catch (SocketTimeoutException s) {
            System.out.println("Socket timed out!");
            break;
         } catch (IOException e) {
            e.printStackTrace();
            break;
         }
      }
   }
   
   public static void main(String [] args) {
      int port = Integer.parseInt(args[0]);
      try {
         Thread t = new GreetingServer(port);
         t.start();
      } catch (IOException e) {
         e.printStackTrace();
      }
   }
}

클라이언트와 서버를 컴파일하고 다음과 같이 서버를 시작하십시오.

$ java GreetingServer 6066
Waiting for client on port 6066...

다음과 같이 클라이언트 프로그램을 확인하십시오-

산출

$ java GreetingClient localhost 6066
Connecting to localhost on port 6066
Just connected to localhost/127.0.0.1:6066
Server says Thank you for connecting to /127.0.0.1:6066
Goodbye!

Java 응용 프로그램을 사용하여 전자 메일을 보내는 것은 간단하지만 시작하려면 JavaMail APIJava Activation Framework (JAF) 컴퓨터에 설치됩니다.

  • Java의 표준 웹 사이트에서 최신 버전의 JavaMail (버전 1.2) 을 다운로드 할 수 있습니다 .

  • Java의 표준 웹 사이트에서 최신 버전의 JAF (버전 1.1.1) 를 다운로드 할 수 있습니다 .

이 파일을 다운로드하고 압축을 풀면 새로 생성 된 최상위 디렉토리에서 두 응용 프로그램에 대한 여러 jar 파일을 찾을 수 있습니다. 추가해야합니다.mail.jaractivation.jar CLASSPATH의 파일.

간단한 이메일 보내기

다음은 기기에서 간단한 이메일을 보내는 예입니다. 귀하의localhost 인터넷에 연결되어 있고 이메일을 보낼 수 있습니다.

// File Name SendEmail.java

import java.util.*;
import javax.mail.*;
import javax.mail.internet.*;
import javax.activation.*;

public class SendEmail {

   public static void main(String [] args) {    
      // Recipient's email ID needs to be mentioned.
      String to = "[email protected]";

      // Sender's email ID needs to be mentioned
      String from = "[email protected]";

      // Assuming you are sending email from localhost
      String host = "localhost";

      // Get system properties
      Properties properties = System.getProperties();

      // Setup mail server
      properties.setProperty("mail.smtp.host", host);

      // Get the default Session object.
      Session session = Session.getDefaultInstance(properties);

      try {
         // Create a default MimeMessage object.
         MimeMessage message = new MimeMessage(session);

         // Set From: header field of the header.
         message.setFrom(new InternetAddress(from));

         // Set To: header field of the header.
         message.addRecipient(Message.RecipientType.TO, new InternetAddress(to));

         // Set Subject: header field
         message.setSubject("This is the Subject Line!");

         // Now set the actual message
         message.setText("This is actual message");

         // Send message
         Transport.send(message);
         System.out.println("Sent message successfully....");
      } catch (MessagingException mex) {
         mex.printStackTrace();
      }
   }
}

이 프로그램을 컴파일하고 실행하여 간단한 이메일을 보내십시오.

산출

$ java SendEmail
Sent message successfully....

여러 수신자에게 이메일을 보내려면 다음 방법을 사용하여 여러 이메일 ID를 지정합니다.

void addRecipients(Message.RecipientType type, Address[] addresses)
   throws MessagingException

다음은 매개 변수에 대한 설명입니다.

  • type− TO, CC 또는 BCC로 설정됩니다. 여기서 CC는 Carbon Copy를 나타내고 BCC는 Black Carbon Copy를 나타냅니다. 예 : Message.RecipientType.TO

  • addresses− 이것은 이메일 ID의 배열입니다. 이메일 ID를 지정하는 동안 InternetAddress () 메서드를 사용해야합니다.

HTML 이메일 보내기

다음은 컴퓨터에서 HTML 이메일을 보내는 예입니다. 여기에서 귀하의localhost 인터넷에 연결되어 있고 이메일을 보낼 수 있습니다.

이 예제는 HTML 내용이 메시지에 포함되도록 지정하기 위해 두 번째 인수가 "text / html"인 내용을 설정하기 위해 setContent () 메서드를 사용한다는 점을 제외하면 이전 예제와 매우 유사합니다.

이 예제를 사용하면 원하는만큼 큰 HTML 콘텐츠를 보낼 수 있습니다.

// File Name SendHTMLEmail.java

import java.util.*;
import javax.mail.*;
import javax.mail.internet.*;
import javax.activation.*;

public class SendHTMLEmail {

   public static void main(String [] args) {
      // Recipient's email ID needs to be mentioned.
      String to = "[email protected]";

      // Sender's email ID needs to be mentioned
      String from = "[email protected]";

      // Assuming you are sending email from localhost
      String host = "localhost";

      // Get system properties
      Properties properties = System.getProperties();

      // Setup mail server
      properties.setProperty("mail.smtp.host", host);

      // Get the default Session object.
      Session session = Session.getDefaultInstance(properties);

      try {
         // Create a default MimeMessage object.
         MimeMessage message = new MimeMessage(session);

         // Set From: header field of the header.
         message.setFrom(new InternetAddress(from));

         // Set To: header field of the header.
         message.addRecipient(Message.RecipientType.TO, new InternetAddress(to));

         // Set Subject: header field
         message.setSubject("This is the Subject Line!");

         // Send the actual HTML message, as big as you like
         message.setContent("<h1>This is actual message</h1>", "text/html");

         // Send message
         Transport.send(message);
         System.out.println("Sent message successfully....");
      } catch (MessagingException mex) {
         mex.printStackTrace();
      }
   }
}

이 프로그램을 컴파일하고 실행하여 HTML 이메일을 보냅니다.

산출

$ java SendHTMLEmail
Sent message successfully....

전자 메일로 첨부 파일 보내기

다음은 기기에서 첨부 파일이있는 이메일을 보내는 예입니다. 여기에서 귀하의localhost 인터넷에 연결되어 있고 이메일을 보낼 수 있습니다.

// File Name SendFileEmail.java

import java.util.*;
import javax.mail.*;
import javax.mail.internet.*;
import javax.activation.*;

public class SendFileEmail {

   public static void main(String [] args) {     
      // Recipient's email ID needs to be mentioned.
      String to = "[email protected]";

      // Sender's email ID needs to be mentioned
      String from = "[email protected]";

      // Assuming you are sending email from localhost
      String host = "localhost";

      // Get system properties
      Properties properties = System.getProperties();

      // Setup mail server
      properties.setProperty("mail.smtp.host", host);

      // Get the default Session object.
      Session session = Session.getDefaultInstance(properties);

      try {
         // Create a default MimeMessage object.
         MimeMessage message = new MimeMessage(session);

         // Set From: header field of the header.
         message.setFrom(new InternetAddress(from));

         // Set To: header field of the header.
         message.addRecipient(Message.RecipientType.TO,new InternetAddress(to));

         // Set Subject: header field
         message.setSubject("This is the Subject Line!");

         // Create the message part 
         BodyPart messageBodyPart = new MimeBodyPart();

         // Fill the message
         messageBodyPart.setText("This is message body");
         
         // Create a multipar message
         Multipart multipart = new MimeMultipart();

         // Set text message part
         multipart.addBodyPart(messageBodyPart);

         // Part two is attachment
         messageBodyPart = new MimeBodyPart();
         String filename = "file.txt";
         DataSource source = new FileDataSource(filename);
         messageBodyPart.setDataHandler(new DataHandler(source));
         messageBodyPart.setFileName(filename);
         multipart.addBodyPart(messageBodyPart);

         // Send the complete message parts
         message.setContent(multipart );

         // Send message
         Transport.send(message);
         System.out.println("Sent message successfully....");
      } catch (MessagingException mex) {
         mex.printStackTrace();
      }
   }
}

이 프로그램을 컴파일하고 실행하여 HTML 이메일을 보냅니다.

산출

$ java SendFileEmail
Sent message successfully....

사용자 인증 부분

인증을 위해 이메일 서버에 사용자 ID와 비밀번호를 제공해야하는 경우 다음과 같이 속성을 설정할 수 있습니다.

props.setProperty("mail.user", "myuser");
props.setProperty("mail.password", "mypwd");

나머지 이메일 전송 메커니즘은 위에서 설명한대로 유지됩니다.

Java는 다중 스레드 프로그래밍 언어 이므로 Java를 사용하여 다중 스레드 프로그램을 개발할 수 있습니다. 다중 스레드 프로그램에는 동시에 실행할 수있는 두 개 이상의 부분이 포함되어 있으며 각 부분은 특히 컴퓨터에 여러 CPU가있는 경우 사용 가능한 리소스를 최적으로 사용하여 동시에 다른 작업을 처리 할 수 ​​있습니다.

정의에 따라 멀티 태스킹은 여러 프로세스가 CPU와 같은 공통 처리 리소스를 공유하는 경우입니다. 멀티 스레딩은 멀티 태스킹의 개념을 단일 애플리케이션 내의 특정 작업을 개별 스레드로 세분화 할 수있는 애플리케이션으로 확장합니다. 각 스레드는 병렬로 실행될 수 있습니다. OS는 처리 시간을 서로 다른 응용 프로그램뿐만 아니라 응용 프로그램 내의 각 스레드간에 나눕니다.

멀티 스레딩을 사용하면 동일한 프로그램에서 여러 활동을 동시에 진행할 수있는 방식으로 작성할 수 있습니다.

스레드의 수명주기

스레드는 수명주기에서 다양한 단계를 거칩니다. 예를 들어 스레드가 생성되고 시작되고 실행 된 다음 죽습니다. 다음 다이어그램은 스레드의 전체 수명주기를 보여줍니다.

다음은 라이프 사이클의 단계입니다.

  • New− 새 스레드는 새 상태에서 수명주기를 시작합니다. 프로그램이 스레드를 시작할 때까지이 상태를 유지합니다. 또한born thread.

  • Runnable− 새로 태어난 스레드가 시작된 후 스레드가 실행 가능해집니다. 이 상태의 스레드는 작업을 실행하는 것으로 간주됩니다.

  • Waiting− 때때로 스레드는 다른 스레드가 작업을 수행하기를 기다리는 동안 대기 상태로 전환됩니다. 스레드는 다른 스레드가 대기중인 스레드에 계속 실행하도록 신호를 보낼 때만 실행 가능 상태로 다시 전환됩니다.

  • Timed Waiting− 실행 가능한 스레드는 지정된 시간 간격 동안 시간 대기 상태로 들어갈 수 있습니다. 이 상태의 스레드는 해당 시간 간격이 만료되거나 대기중인 이벤트가 발생하면 다시 실행 가능 상태로 전환됩니다.

  • Terminated (Dead) − 실행 가능한 스레드는 작업을 완료하거나 그렇지 않으면 종료 될 때 종료 됨 상태에 들어갑니다.

스레드 우선 순위

모든 Java 스레드에는 운영 체제가 스레드가 예약되는 순서를 결정하는 데 도움이되는 우선 순위가 있습니다.

Java 스레드 우선 순위는 MIN_PRIORITY (상수 1)와 MAX_PRIORITY (상수 10) 사이의 범위에 있습니다. 기본적으로 모든 스레드에는 우선 순위 NORM_PRIORITY (상수 5)가 지정됩니다.

우선 순위가 높은 스레드는 프로그램에 더 중요하며 우선 순위가 낮은 스레드보다 먼저 프로세서 시간을 할당해야합니다. 그러나 스레드 우선 순위는 스레드가 실행되는 순서를 보장 할 수 없으며 플랫폼에 크게 의존합니다.

실행 가능한 인터페이스를 구현하여 스레드 생성

클래스가 스레드로 실행되도록 의도 된 경우 다음을 구현하여이를 달성 할 수 있습니다. Runnable상호 작용. 세 가지 기본 단계를 따라야합니다.

1 단계

첫 번째 단계로에서 제공하는 run () 메서드를 구현해야합니다. Runnable상호 작용. 이 메서드는 스레드에 대한 진입 점을 제공하며이 메서드에 전체 비즈니스 논리를 넣습니다. 다음은 run () 메소드의 간단한 구문입니다.

public void run( )

2 단계

두 번째 단계로 Thread 다음 생성자를 사용하여 객체-

Thread(Runnable threadObj, String threadName);

여기서 threadObj 는 다음을 구현하는 클래스의 인스턴스입니다.Runnable 인터페이스 및 threadName 새 스레드에 지정된 이름입니다.

3 단계

Thread 객체가 생성되면 다음을 호출하여 시작할 수 있습니다. start()메서드는 run () 메서드에 대한 호출을 실행합니다. 다음은 start () 메서드의 간단한 구문입니다.

void start();

다음은 새 스레드를 만들고 실행을 시작하는 예입니다.

class RunnableDemo implements Runnable {
   private Thread t;
   private String threadName;
   
   RunnableDemo( String name) {
      threadName = name;
      System.out.println("Creating " +  threadName );
   }
   
   public void run() {
      System.out.println("Running " +  threadName );
      try {
         for(int i = 4; i > 0; i--) {
            System.out.println("Thread: " + threadName + ", " + i);
            // Let the thread sleep for a while.
            Thread.sleep(50);
         }
      } catch (InterruptedException e) {
         System.out.println("Thread " +  threadName + " interrupted.");
      }
      System.out.println("Thread " +  threadName + " exiting.");
   }
   
   public void start () {
      System.out.println("Starting " +  threadName );
      if (t == null) {
         t = new Thread (this, threadName);
         t.start ();
      }
   }
}

public class TestThread {

   public static void main(String args[]) {
      RunnableDemo R1 = new RunnableDemo( "Thread-1");
      R1.start();
      
      RunnableDemo R2 = new RunnableDemo( "Thread-2");
      R2.start();
   }   
}

이것은 다음 결과를 생성합니다-

산출

Creating Thread-1
Starting Thread-1
Creating Thread-2
Starting Thread-2
Running Thread-1
Thread: Thread-1, 4
Running Thread-2
Thread: Thread-2, 4
Thread: Thread-1, 3
Thread: Thread-2, 3
Thread: Thread-1, 2
Thread: Thread-2, 2
Thread: Thread-1, 1
Thread: Thread-2, 1
Thread Thread-1 exiting.
Thread Thread-2 exiting.

스레드 클래스를 확장하여 스레드 만들기

스레드를 만드는 두 번째 방법은 다음을 확장하는 새 클래스를 만드는 것입니다. Thread다음 두 가지 간단한 단계를 사용하여 클래스. 이 접근 방식은 Thread 클래스에서 사용 가능한 메서드를 사용하여 생성 된 여러 스레드를 처리하는 데 더 많은 유연성을 제공합니다.

1 단계

재정의해야합니다. run( )Thread 클래스에서 사용할 수있는 메서드. 이 메서드는 스레드에 대한 진입 점을 제공하며이 메서드에 전체 비즈니스 논리를 넣습니다. 다음은 run () 메소드의 간단한 구문입니다.

public void run( )

2 단계

Thread 객체가 생성되면 다음을 호출하여 시작할 수 있습니다. start()메서드는 run () 메서드에 대한 호출을 실행합니다. 다음은 start () 메서드의 간단한 구문입니다.

void start( );

다음은 스레드를 확장하기 위해 재 작성된 이전 프로그램입니다.

class ThreadDemo extends Thread {
   private Thread t;
   private String threadName;
   
   ThreadDemo( String name) {
      threadName = name;
      System.out.println("Creating " +  threadName );
   }
   
   public void run() {
      System.out.println("Running " +  threadName );
      try {
         for(int i = 4; i > 0; i--) {
            System.out.println("Thread: " + threadName + ", " + i);
            // Let the thread sleep for a while.
            Thread.sleep(50);
         }
      } catch (InterruptedException e) {
         System.out.println("Thread " +  threadName + " interrupted.");
      }
      System.out.println("Thread " +  threadName + " exiting.");
   }
   
   public void start () {
      System.out.println("Starting " +  threadName );
      if (t == null) {
         t = new Thread (this, threadName);
         t.start ();
      }
   }
}

public class TestThread {

   public static void main(String args[]) {
      ThreadDemo T1 = new ThreadDemo( "Thread-1");
      T1.start();
      
      ThreadDemo T2 = new ThreadDemo( "Thread-2");
      T2.start();
   }   
}

이것은 다음 결과를 생성합니다-

산출

Creating Thread-1
Starting Thread-1
Creating Thread-2
Starting Thread-2
Running Thread-1
Thread: Thread-1, 4
Running Thread-2
Thread: Thread-2, 4
Thread: Thread-1, 3
Thread: Thread-2, 3
Thread: Thread-1, 2
Thread: Thread-2, 2
Thread: Thread-1, 1
Thread: Thread-2, 1
Thread Thread-1 exiting.
Thread Thread-2 exiting.

스레드 방법

다음은 Thread 클래스에서 사용할 수있는 중요한 메서드 목록입니다.

Sr. 아니. 방법 및 설명
1

public void start()

별도의 실행 경로에서 스레드를 시작한 다음이 Thread 객체에서 run () 메서드를 호출합니다.

2

public void run()

이 Thread 객체가 별도의 Runnable 대상을 사용하여 인스턴스화 된 경우 해당 Runnable 객체에서 run () 메서드가 호출됩니다.

public final void setName(String name)

Thread 개체의 이름을 변경합니다. 이름을 검색하기위한 getName () 메소드도 있습니다.

4

public final void setPriority(int priority)

이 Thread 객체의 우선 순위를 설정합니다. 가능한 값은 1에서 10 사이입니다.

5

public final void setDaemon(boolean on)

true 매개 변수는이 스레드를 데몬 스레드로 나타냅니다.

6

public final void join(long millisec)

현재 스레드는 두 번째 스레드에서이 메서드를 호출하여 두 번째 스레드가 종료되거나 지정된 밀리 초가 경과 할 때까지 현재 스레드가 차단되도록합니다.

7

public void interrupt()

이 스레드를 중단하여 어떤 이유로 든 차단 된 경우 계속 실행되도록합니다.

8

public final boolean isAlive()

스레드가 활성화 된 경우 true를 반환합니다. 이는 스레드가 시작된 후 완료되기 전의 시간입니다.

이전 메서드는 특정 Thread 개체에서 호출됩니다. Thread 클래스의 다음 메서드는 정적입니다. 정적 메서드 중 하나를 호출하면 현재 실행중인 스레드에서 작업이 수행됩니다.

Sr. 아니. 방법 및 설명
1

public static void yield()

현재 실행중인 스레드가 예약 대기중인 동일한 우선 순위의 다른 스레드에 양보하도록합니다.

2

public static void sleep(long millisec)

현재 실행중인 스레드가 지정된 밀리 초 이상 동안 차단되도록합니다.

public static boolean holdsLock(Object x)

현재 스레드가 지정된 Object에 대한 잠금을 보유하고 있으면 true를 반환합니다.

4

public static Thread currentThread()

이 메서드를 호출하는 스레드 인 현재 실행중인 스레드에 대한 참조를 반환합니다.

5

public static void dumpStack()

다중 스레드 응용 프로그램을 디버깅 할 때 유용한 현재 실행중인 스레드에 대한 스택 추적을 인쇄합니다.

다음 ThreadClassDemo 프로그램은 Thread 클래스의 이러한 메서드 중 일부를 보여줍니다. 수업 고려DisplayMessage 구현하는 Runnable

// File Name : DisplayMessage.java
// Create a thread to implement Runnable

public class DisplayMessage implements Runnable {
   private String message;
   
   public DisplayMessage(String message) {
      this.message = message;
   }
   
   public void run() {
      while(true) {
         System.out.println(message);
      }
   }
}

다음은 Thread 클래스를 확장하는 또 다른 클래스입니다.

// File Name : GuessANumber.java
// Create a thread to extentd Thread

public class GuessANumber extends Thread {
   private int number;
   public GuessANumber(int number) {
      this.number = number;
   }
   
   public void run() {
      int counter = 0;
      int guess = 0;
      do {
         guess = (int) (Math.random() * 100 + 1);
         System.out.println(this.getName() + " guesses " + guess);
         counter++;
      } while(guess != number);
      System.out.println("** Correct!" + this.getName() + "in" + counter + "guesses.**");
   }
}

다음은 위에 정의 된 클래스를 사용하는 주요 프로그램입니다.

// File Name : ThreadClassDemo.java
public class ThreadClassDemo {

   public static void main(String [] args) {
      Runnable hello = new DisplayMessage("Hello");
      Thread thread1 = new Thread(hello);
      thread1.setDaemon(true);
      thread1.setName("hello");
      System.out.println("Starting hello thread...");
      thread1.start();
      
      Runnable bye = new DisplayMessage("Goodbye");
      Thread thread2 = new Thread(bye);
      thread2.setPriority(Thread.MIN_PRIORITY);
      thread2.setDaemon(true);
      System.out.println("Starting goodbye thread...");
      thread2.start();

      System.out.println("Starting thread3...");
      Thread thread3 = new GuessANumber(27);
      thread3.start();
      try {
         thread3.join();
      } catch (InterruptedException e) {
         System.out.println("Thread interrupted.");
      }
      System.out.println("Starting thread4...");
      Thread thread4 = new GuessANumber(75);
      
      thread4.start();
      System.out.println("main() is ending...");
   }
}

그러면 다음과 같은 결과가 생성됩니다. 이 예제를 반복해서 시도 할 수 있으며 매번 다른 결과를 얻을 수 있습니다.

산출

Starting hello thread...
Starting goodbye thread...
Hello
Hello
Hello
Hello
Hello
Hello
Goodbye
Goodbye
Goodbye
Goodbye
Goodbye
.......

주요 Java 멀티 스레딩 개념

Java에서 멀티 스레딩 프로그래밍을 수행하는 동안 다음 개념이 매우 편리해야합니다.

  • 스레드 동기화 란 무엇입니까?

  • 스레드 간 통신 처리

  • 스레드 교착 상태 처리

  • 주요 스레드 작업

applet웹 브라우저에서 실행되는 Java 프로그램입니다. 애플릿은 전체 Java API를 자유롭게 사용할 수 있으므로 완전한 기능을 갖춘 Java 응용 프로그램이 될 수 있습니다.

다음을 포함하여 애플릿과 독립형 Java 응용 프로그램 사이에는 몇 가지 중요한 차이점이 있습니다.

  • 애플릿은 java.applet.Applet 클래스를 확장하는 Java 클래스입니다.

  • main () 메소드는 애플릿에서 호출되지 않으며 애플릿 클래스는 main ()을 정의하지 않습니다.

  • 애플릿은 HTML 페이지에 포함되도록 설계되었습니다.

  • 사용자가 애플릿이 포함 된 HTML 페이지를 볼 때 애플릿에 대한 코드가 사용자의 컴퓨터로 다운로드됩니다.

  • 애플릿을 보려면 JVM이 필요합니다. JVM은 웹 브라우저의 플러그인이거나 별도의 런타임 환경 일 수 있습니다.

  • 사용자 시스템의 JVM은 애플릿 클래스의 인스턴스를 만들고 애플릿의 수명 동안 다양한 메서드를 호출합니다.

  • 애플릿에는 웹 브라우저에서 시행하는 엄격한 보안 규칙이 있습니다. 애플릿의 보안은 종종 샌드 박스 보안이라고 불리며, 따라야 할 다양한 규칙을 사용하여 애플릿을 샌드 박스에서 놀고있는 아이와 비교합니다.

  • 애플릿에 필요한 다른 클래스는 단일 JAR (Java Archive) 파일로 다운로드 할 수 있습니다.

애플릿의 수명주기

Applet 클래스의 네 가지 메서드는 심각한 애플릿을 구축하는 프레임 워크를 제공합니다.

  • init−이 방법은 애플릿에 필요한 모든 초기화를위한 것입니다. 애플릿 태그 내부의 param 태그가 처리 된 후에 호출됩니다.

  • start−이 메서드는 브라우저가 init 메서드를 호출 한 후 자동으로 호출됩니다. 사용자가 다른 페이지로 이동 한 후 애플릿이 포함 된 페이지로 돌아갈 때마다 호출됩니다.

  • stop−이 메서드는 사용자가 애플릿이있는 페이지를 벗어날 때 자동으로 호출됩니다. 따라서 동일한 애플릿에서 반복적으로 호출 할 수 있습니다.

  • destroy−이 메서드는 브라우저가 정상적으로 종료 될 때만 호출됩니다. 애플릿은 HTML 페이지에 있어야하기 때문에 일반적으로 사용자가 애플릿이 포함 된 페이지를 떠난 후 리소스를 남겨두면 안됩니다.

  • paint− start () 메서드 직후에 호출되며, 또한 애플릿이 브라우저에서 자체적으로 다시 그려야 할 때마다 호출됩니다. paint () 메소드는 실제로 java.awt에서 상속됩니다.

"Hello, World"애플릿

다음은 HelloWorldApplet.java라는 간단한 애플릿입니다.

import java.applet.*;
import java.awt.*;

public class HelloWorldApplet extends Applet {
   public void paint (Graphics g) {
      g.drawString ("Hello World", 25, 50);
   }
}

이러한 import 문은 클래스를 애플릿 클래스의 범위로 가져옵니다.

  • java.applet.Applet
  • java.awt.Graphics

이러한 import 문이 없으면 Java 컴파일러는 애플릿 클래스가 참조하는 Applet 및 Graphics 클래스를 인식하지 못합니다.

애플릿 클래스

모든 애플릿은 java.applet.Applet 클래스 의 확장입니다 . 기본 Applet 클래스는 파생 된 Applet 클래스가 브라우저 컨텍스트에서 정보와 서비스를 얻기 위해 호출 할 수있는 메서드를 제공합니다.

여기에는 다음을 수행하는 방법이 포함됩니다.

  • 애플릿 매개 변수 가져 오기
  • 애플릿이 포함 된 HTML 파일의 네트워크 위치를 가져옵니다.
  • 애플릿 클래스 디렉토리의 네트워크 위치 얻기
  • 브라우저에서 상태 메시지 인쇄
  • 이미지 가져 오기
  • 오디오 클립 가져 오기
  • 오디오 클립 재생
  • 애플릿 크기 조정

또한 Applet 클래스는 뷰어 또는 브라우저가 애플릿에 대한 정보를 얻고 애플릿의 실행을 제어하는 ​​인터페이스를 제공합니다. 시청자는-

  • 애플릿의 작성자, 버전 및 저작권에 대한 정보 요청
  • 애플릿이 인식하는 매개 변수에 대한 설명 요청
  • 애플릿 초기화
  • 애플릿 파괴
  • 애플릿 실행 시작
  • 애플릿 실행 중지

Applet 클래스는 이러한 각 메서드의 기본 구현을 제공합니다. 이러한 구현은 필요에 따라 재정의 될 수 있습니다.

"Hello, World"애플릿은 그대로 완성되었습니다. 재정의 된 유일한 방법은 paint 방법입니다.

애플릿 호출

HTML 파일에 지시문을 임베드하고 애플릿 뷰어 또는 Java 사용 가능 브라우저를 통해 파일을 보는 방법으로 애플릿을 호출 할 수 있습니다.

<applet> 태그는 HTML 파일에 애플릿을 포함하기위한 기초입니다. 다음은 "Hello, World"애플릿을 호출하는 예입니다.

<html>
   <title>The Hello, World Applet</title>
   <hr>
   <applet code = "HelloWorldApplet.class" width = "320" height = "120">
      If your browser was Java-enabled, a "Hello, World"
      message would appear here.
   </applet>
   <hr>
</html>

Note− HTML에서 애플릿 을 호출하는 방법에 대한 자세한 내용은 HTML Applet Tag 를 참조 할 수 있습니다 .

<applet> 태그의 코드 속성이 필요합니다. 실행할 Applet 클래스를 지정합니다. 애플릿이 실행되는 패널의 초기 크기를 지정하려면 너비와 높이도 필요합니다. 애플릿 지시문은 </ applet> 태그로 닫아야합니다.

애플릿이 매개 변수를 사용하는 경우 <applet>과 </ applet> 사이에 <param> 태그를 추가하여 매개 변수에 대한 값을 전달할 수 있습니다. 브라우저는 애플릿 태그 사이의 텍스트 및 기타 태그를 무시합니다.

Java를 사용할 수없는 브라우저는 <applet> 및 </ applet>을 처리하지 않습니다. 따라서 애플릿과 관련이없는 태그 사이에 나타나는 모든 것은 Java를 사용할 수없는 브라우저에서 볼 수 있습니다.

뷰어 또는 브라우저는 문서 위치에서 컴파일 된 Java 코드를 찾습니다. 다르게 지정하려면 다음과 같이 <applet> 태그의 코드베이스 속성을 사용하십시오.

<applet codebase = "https://amrood.com/applets" code = "HelloWorldApplet.class"
   width = "320" height = "120">

애플릿이 기본값이 아닌 패키지에있는 경우 패키지 / 클래스 구성 요소를 구분하려면 마침표 (.)를 사용하여 코드 속성에 보관 패키지를 지정해야합니다. 예를 들면-

<applet  = "mypackage.subpackage.TestApplet.class" 
   width = "320" height = "120">

애플릿 매개 변수 얻기

다음 예제는 애플릿이 문서에 지정된 설정 매개 변수에 응답하도록 만드는 방법을 보여줍니다. 이 애플릿은 검정과 두 번째 색상의 바둑판 패턴을 표시합니다.

두 번째 색상과 각 사각형의 크기는 문서 내의 애플릿에 대한 매개 변수로 지정할 수 있습니다.

CheckerApplet은 init () 메서드에서 매개 변수를 가져옵니다. paint () 메서드에서 매개 변수를 가져올 수도 있습니다. 그러나 새로 고칠 때마다 값을 가져오고 애플릿을 시작할 때마다 설정을 저장하는 것이 편리하고 효율적입니다.

애플릿 뷰어 또는 브라우저는 실행되는 각 애플릿의 init () 메서드를 호출합니다. 뷰어는 애플릿을로드 한 직후에 init ()를 한 번 호출합니다. (Applet.init ()는 아무것도하지 않도록 구현됩니다.) 사용자 정의 초기화 코드를 삽입하려면 기본 구현을 재정의하십시오.

Applet.getParameter () 메서드는 매개 변수 이름이 지정된 매개 변수를 가져옵니다 (매개 변수 값은 항상 문자열 임). 값이 숫자 또는 기타 비 문자 데이터 인 경우 문자열을 구문 분석해야합니다.

다음은 CheckerApplet.java의 골격입니다-

import java.applet.*;
import java.awt.*;

public class CheckerApplet extends Applet {
   int squareSize = 50;   // initialized to default size
   public void init() {}
   private void parseSquareSize (String param) {}
   private Color parseColor (String param) {}
   public void paint (Graphics g) {}
}

다음은 CheckerApplet의 init () 및 private parseSquareSize () 메서드입니다.

public void init () {
   String squareSizeParam = getParameter ("squareSize");
   parseSquareSize (squareSizeParam);
   
   String colorParam = getParameter ("color");
   Color fg = parseColor (colorParam);
   
   setBackground (Color.black);
   setForeground (fg);
}

private void parseSquareSize (String param) {
   if (param == null) return;
   try {
      squareSize = Integer.parseInt (param);
   } catch (Exception e) {
      // Let default value remain
   }
}

애플릿은 parseSquareSize ()를 호출하여 squareSize 매개 변수를 구문 분석합니다. parseSquareSize ()는 문자열을 구문 분석하고 정수를 반환하는 라이브러리 메서드 Integer.parseInt ()를 호출합니다. Integer.parseInt ()는 인수가 유효하지 않을 때마다 예외를 발생시킵니다.

따라서 parseSquareSize ()는 잘못된 입력에서 애플릿이 실패하는 것을 허용하지 않고 예외를 포착합니다.

애플릿은 parseColor ()를 호출하여 색상 매개 변수를 색상 값으로 구문 분석합니다. parseColor ()는 매개 변수 값을 미리 정의 된 색상의 이름과 일치시키기 위해 일련의 문자열 비교를 수행합니다. 이 애플릿이 작동하도록하려면 이러한 메소드를 구현해야합니다.

애플릿 매개 변수 지정

다음은 CheckerApplet이 포함 된 HTML 파일의 예입니다. HTML 파일은 <param> 태그를 사용하여 애플릿에 두 매개 변수를 모두 지정합니다.

<html>
   <title>Checkerboard Applet</title>
   <hr>
   <applet code = "CheckerApplet.class" width = "480" height = "320">
      <param name = "color" value = "blue">
      <param name = "squaresize" value = "30">
   </applet>
   <hr>
</html>

Note − 매개 변수 이름은 대소 문자를 구분하지 않습니다.

애플릿으로 애플리케이션 변환

그래픽 Java 애플리케이션 (즉, AWT를 사용하고 Java 프로그램 실행기로 시작할 수있는 애플리케이션)을 웹 페이지에 임베드 할 수있는 애플릿으로 쉽게 변환 할 수 있습니다.

다음은 응용 프로그램을 애플릿으로 변환하는 특정 단계입니다.

  • 애플릿 코드를로드하기위한 적절한 태그로 HTML 페이지를 만드십시오.

  • JApplet 클래스의 서브 클래스를 제공하십시오. 이 수업을 공개합니다. 그렇지 않으면 애플릿을로드 할 수 없습니다.

  • 응용 프로그램에서 주요 방법을 제거하십시오. 응용 프로그램에 대한 프레임 창을 구성하지 마십시오. 애플리케이션이 브라우저 내에 표시됩니다.

  • 프레임 창 생성자에서 애플릿의 init 메서드로 초기화 코드를 이동합니다. 애플릿 개체를 명시 적으로 구성 할 필요는 없습니다. 브라우저는이를 인스턴스화하고 init 메소드를 호출합니다.

  • setSize에 대한 호출을 제거하십시오. 애플릿의 경우 크기 조정은 HTML 파일의 너비 및 높이 매개 변수로 수행됩니다.

  • setDefaultCloseOperation에 대한 호출을 제거하십시오. 애플릿은 닫을 수 없습니다. 브라우저가 종료되면 종료됩니다.

  • 애플리케이션이 setTitle을 호출하는 경우 메소드에 대한 호출을 제거하십시오. 애플릿은 제목 표시 줄을 가질 수 없습니다. (물론 HTML 제목 태그를 사용하여 웹 페이지 자체의 제목을 지정할 수 있습니다.)

  • setVisible (true)을 호출하지 마십시오. 애플릿이 자동으로 표시됩니다.

이벤트 처리

애플릿은 Container 클래스에서 이벤트 처리 메서드 그룹을 상속합니다. Container 클래스는 특정 유형의 이벤트를 처리하기위한 processKeyEvent 및 processMouseEvent와 같은 여러 메서드와 processEvent라는 하나의 catch-all 메서드를 정의합니다.

이벤트에 반응하려면 애플릿이 적절한 이벤트 별 방법을 재정의해야합니다.

import java.awt.event.MouseListener;
import java.awt.event.MouseEvent;
import java.applet.Applet;
import java.awt.Graphics;

public class ExampleEventHandling extends Applet implements MouseListener {
   StringBuffer strBuffer;

   public void init() {
      addMouseListener(this);
      strBuffer = new StringBuffer();
      addItem("initializing the apple ");
   }

   public void start() {
      addItem("starting the applet ");
   }

   public void stop() {
      addItem("stopping the applet ");
   }

   public void destroy() {
      addItem("unloading the applet");
   }

   void addItem(String word) {
      System.out.println(word);
      strBuffer.append(word);
      repaint();
   }

   public void paint(Graphics g) {
      // Draw a Rectangle around the applet's display area.
      g.drawRect(0, 0, 
      getWidth() - 1,
      getHeight() - 1);

      // display the string inside the rectangle.
      g.drawString(strBuffer.toString(), 10, 20);
   }

   
   public void mouseEntered(MouseEvent event) {
   }
   public void mouseExited(MouseEvent event) {
   }
   public void mousePressed(MouseEvent event) {
   }
   public void mouseReleased(MouseEvent event) {
   }
   public void mouseClicked(MouseEvent event) {
      addItem("mouse clicked! ");
   }
}

이제이 애플릿을 다음과 같이 부릅니다.

<html>
   <title>Event Handling</title>
   <hr>
   <applet code = "ExampleEventHandling.class" 
      width = "300" height = "300">
   </applet>
   <hr>
</html>

처음에는 애플릿에 "애플릿 초기화 중. 애플릿 시작 중"이 표시됩니다. 그런 다음 사각형 내부를 클릭하면 "마우스 클릭"도 표시됩니다.

이미지 표시

애플릿은 GIF, JPEG, BMP 및 기타 형식의 이미지를 표시 할 수 있습니다. 애플릿 내에 이미지를 표시하려면 java.awt.Graphics 클래스에있는 drawImage () 메소드를 사용합니다.

다음은 이미지를 표시하는 모든 단계를 설명하는 예입니다.

import java.applet.*;
import java.awt.*;
import java.net.*;

public class ImageDemo extends Applet {
   private Image image;
   private AppletContext context;
   
   public void init() {
      context = this.getAppletContext();
      String imageURL = this.getParameter("image");
      if(imageURL == null) {
         imageURL = "java.jpg";
      }
      try {
         URL url = new URL(this.getDocumentBase(), imageURL);
         image = context.getImage(url);
      } catch (MalformedURLException e) {
         e.printStackTrace();
         // Display in browser status bar
         context.showStatus("Could not load image!");
      }
   }
   
   public void paint(Graphics g) {
      context.showStatus("Displaying image");
      g.drawImage(image, 0, 0, 200, 84, null);
      g.drawString("www.javalicense.com", 35, 100);
   }  
}

이제이 애플릿을 다음과 같이 부릅니다.

<html>
   <title>The ImageDemo applet</title>
   <hr>
   <applet code = "ImageDemo.class" width = "300" height = "200">
      <param name = "image" value = "java.jpg">
   </applet>
   <hr>
</html>

오디오 재생

애플릿은 java.applet 패키지의 AudioClip 인터페이스가 나타내는 오디오 파일을 재생할 수 있습니다. AudioClip 인터페이스에는 다음과 같은 세 가지 방법이 있습니다.

  • public void play() − 오디오 클립을 처음부터 한 번 재생합니다.

  • public void loop() − 오디오 클립이 계속 재생되도록합니다.

  • public void stop() − 오디오 클립 재생을 중지합니다.

AudioClip 객체를 얻으려면 Applet 클래스의 getAudioClip () 메서드를 호출해야합니다. getAudioClip () 메서드는 URL이 실제 오디오 파일로 확인되는지 여부에 관계없이 즉시 반환됩니다. 오디오 파일은 오디오 클립 재생을 시도 할 때까지 다운로드되지 않습니다.

다음은 오디오를 재생하는 모든 단계를 보여주는 예입니다.

import java.applet.*;
import java.awt.*;
import java.net.*;

public class AudioDemo extends Applet {
   private AudioClip clip;
   private AppletContext context;
   
   public void init() {
      context = this.getAppletContext();
      String audioURL = this.getParameter("audio");
      if(audioURL == null) {
         audioURL = "default.au";
      }
      try {
         URL url = new URL(this.getDocumentBase(), audioURL);
         clip = context.getAudioClip(url);
      } catch (MalformedURLException e) {
         e.printStackTrace();
         context.showStatus("Could not load audio file!");
      }
   }
   
   public void start() {
      if(clip != null) {
         clip.loop();
      }
   }
   
   public void stop() {
      if(clip != null) {
         clip.stop();
      }
   }
}

이제이 애플릿을 다음과 같이 부릅니다.

<html>
   <title>The ImageDemo applet</title>
   <hr>
   <applet code = "ImageDemo.class" width = "0" height = "0">
      <param name = "audio" value = "test.wav">
   </applet>
   <hr>
</html>

PC에서 test.wav를 사용하여 위의 예를 테스트 할 수 있습니다.

자바 언어는 세 가지 유형의 주석을 지원합니다.

Sr. 아니. 설명 및 설명
1

/* text */

컴파일러는 / *에서 * /까지 모든 것을 무시합니다.

2

//text

컴파일러는 //부터 줄 끝까지 모든 것을 무시합니다.

/** documentation */

이것은 문서 주석이며 일반적으로 doc comment. 그만큼JDK javadoc도구는 자동으로 생성 된 문서를 준비 할 때 문서 주석을 사용 합니다.

이 장은 Javadoc에 대해 설명합니다. Javadoc을 사용하여 Java 코드에 대한 유용한 문서를 생성하는 방법을 살펴 보겠습니다.

Javadoc이란 무엇입니까?

Javadoc은 JDK와 함께 제공되는 도구이며 사전 정의 된 형식의 문서가 필요한 Java 소스 코드에서 HTML 형식의 Java 코드 문서를 생성하는 데 사용됩니다.

다음은 /*….*/ 안의 줄이 Java 다중 줄 주석 인 간단한 예입니다. 마찬가지로 // 앞에 오는 줄은 Java 한 줄 주석입니다.

/**
* The HelloWorld program implements an application that
* simply displays "Hello World!" to the standard output.
*
* @author  Zara Ali
* @version 1.0
* @since   2014-03-31 
*/
public class HelloWorld {

   public static void main(String[] args) {
      // Prints Hello, World! on standard output.
      System.out.println("Hello World!");
   }
}

설명 부분에 필수 HTML 태그를 포함 할 수 있습니다. 예를 들어, 다음 예제에서는 제목에 <h1> .... </ h1>을 사용하고 단락 나누기를 만드는 데 <p>를 사용했습니다.

/**
* <h1>Hello, World!</h1>
* The HelloWorld program implements an application that
* simply displays "Hello World!" to the standard output.
* <p>
* Giving proper comments in your program makes it more
* user friendly and it is assumed as a high quality code.
* 
*
* @author  Zara Ali
* @version 1.0
* @since   2014-03-31 
*/
public class HelloWorld {

   public static void main(String[] args) {
      // Prints Hello, World! on standard output.
      System.out.println("Hello World!");
   }
}

javadoc 태그

javadoc 도구는 다음 태그를 인식합니다.

꼬리표 기술 통사론
@저자 클래스 작성자를 추가합니다. @ 저자 이름-텍스트
{@암호} 텍스트를 HTML 마크 업 또는 중첩 된 javadoc 태그로 해석하지 않고 코드 글꼴로 텍스트를 표시합니다. {@code text}
{@docRoot} 생성 된 페이지에서 생성 된 문서의 루트 디렉토리에 대한 상대 경로를 나타냅니다. {@docRoot}
@deprecated 이 API를 더 이상 사용하지 않아야 함을 나타내는 주석을 추가합니다. @deprecated deprecatedtext
@예외 추가 Throws 클래스 이름 및 설명 텍스트와 함께 생성 된 문서의 부제목. @exception 클래스 이름 설명
{@inheritDoc} 에서 주석을 상속합니다. nearest 상속 가능한 클래스 또는 구현 가능한 인터페이스. 즉각적인 surperclass에서 주석을 상속합니다.
{@링크} 참조 된 클래스의 지정된 패키지, 클래스 또는 멤버 이름에 대한 설명서를 가리키는 표시 텍스트 레이블이있는 인라인 링크를 삽입합니다. {@link package.class # member label}
{@linkplain} 링크의 레이블이 코드 글꼴이 아닌 일반 텍스트로 표시된다는 점을 제외하면 {@link}와 동일합니다. {@linkplain package.class # member label}
@param "Parameters"섹션에 지정된 매개 변수 이름 뒤에 지정된 설명이있는 매개 변수를 추가합니다. @param 매개 변수 이름 설명
@반환 설명 텍스트와 함께 "반품"섹션을 추가합니다. @return 설명
@보다 참조를 가리키는 링크 또는 텍스트 항목과 함께 "참고 항목"제목을 추가합니다. @ 참조 참조
@연속물 직렬화 가능한 기본 필드의 문서 주석에 사용됩니다. @serial 필드 설명 | 포함 | 들어오지 못하게 하다
@serialData writeObject () 또는 writeExternal () 메서드로 쓴 데이터를 문서화합니다. @serialData 데이터 설명
안녕하세요. ObjectStreamField 구성 요소를 문서화합니다. @serialField 필드 이름 필드 유형 필드 설명
@이후 생성 된 문서에 지정된 이후 텍스트가있는 "Since"표제를 추가합니다. @ 출시 이후
@throws @throws 및 @exception 태그는 동의어입니다. @throws 클래스 이름 설명
{@값} 정적 필드의 문서 주석에 {@value}가 사용되면 해당 상수의 값이 표시됩니다. {@value package.class # field}
@버전 -version 옵션을 사용할 때 생성 된 문서에 지정된 버전 텍스트가있는 "버전"부제목을 추가합니다. @ 버전 버전 텍스트

다음 프로그램은 문서 주석에 사용할 수있는 중요한 태그를 거의 사용하지 않습니다. 요구 사항에 따라 다른 태그를 사용할 수 있습니다.

AddNum 클래스에 대한 문서는 HTML 파일 AddNum.html로 생성되지만 동시에 index.html이라는 이름의 마스터 파일도 생성됩니다.

import java.io.*;

/**
* <h1>Add Two Numbers!</h1>
* The AddNum program implements an application that
* simply adds two given integer numbers and Prints
* the output on the screen.
* <p>
* <b>Note:</b> Giving proper comments in your program makes it more
* user friendly and it is assumed as a high quality code.
*
* @author  Zara Ali
* @version 1.0
* @since   2014-03-31
*/
public class AddNum {
   /**
   * This method is used to add two integers. This is
   * a the simplest form of a class method, just to
   * show the usage of various javadoc Tags.
   * @param numA This is the first paramter to addNum method
   * @param numB  This is the second parameter to addNum method
   * @return int This returns sum of numA and numB.
   */
   public int addNum(int numA, int numB) {
      return numA + numB;
   }

   /**
   * This is the main method which makes use of addNum method.
   * @param args Unused.
   * @return Nothing.
   * @exception IOException On input error.
   * @see IOException
   */

   public static void main(String args[]) throws IOException {
      AddNum obj = new AddNum();
      int sum = obj.addNum(10, 20);

      System.out.println("Sum of 10 and 20 is :" + sum);
   }
}

이제 다음과 같이 javadoc 유틸리티를 사용하여 위의 AddNum.java 파일을 처리하십시오.

$ javadoc AddNum.java
Loading source file AddNum.java...
Constructing Javadoc information...
Standard Doclet version 1.7.0_51
Building tree for all the packages and classes...
Generating /AddNum.html...
AddNum.java:36: warning - @return tag cannot be used in method with void return type.
Generating /package-frame.html...
Generating /package-summary.html...
Generating /package-tree.html...
Generating /constant-values.html...
Building index for all the packages and classes...
Generating /overview-tree.html...
Generating /index-all.html...
Generating /deprecated-list.html...
Building index for all classes...
Generating /allclasses-frame.html...
Generating /allclasses-noframe.html...
Generating /index.html...
Generating /help-doc.html...
1 warning
$

생성 된 모든 문서는 여기에서 확인할 수 있습니다 -AddNum . JDK 1.7을 사용하는 경우 javadoc은 훌륭한stylesheet.css에서 표준 스타일 시트를 다운로드하여 사용하는 것이 좋습니다. https://docs.oracle.com/javase/7/docs/api/stylesheet.css