@Override 주석은 개발자가 동일한 함수 이름을 사용하기 위해 Java에서 함수를 재정의하지만 이러한 함수에 다른 속성을 할당할 때 사용됩니다. Java의 초과 상승 기능을 알고 있지만 @override 주석을 명시적으로 작성하기 위한 필수 옵션으로 사용하고 싶지 않았기 때문에 @override 주석을 사용하지 않은 경우. Java 1.5가 도입된 이후 기본적으로 활성화됩니다. 런타임 다형성을 촉진합니다. 주석을 사용하지 않고도 모든 기능을 재정의할 수 있기 때문입니다. 그럼에도 불구하고 한 가지 큰 이점이 있습니다. 컴파일러가 우연히 재정의를 놓친 경우(예: 개발자가 재정의 함수 이름에서 철자를 실수한 경우)입니다. 주석 재정의의 도움으로 컴파일러는 기본 함수를 하위 함수로 이해하고 재정의합니다. 또한 코드 가독성이 향상되어 유지 관리 시간과 노력이 줄어듭니다.
무료 소프트웨어 개발 과정 시작
웹 개발, 프로그래밍 언어, 소프트웨어 테스팅 등
구문:
public @interface Override
컴파일러가 주석인지 아닌지를 이해할 수 있도록 키워드를 재정의하려면 앞에 "@" 기호가 있어야 합니다. 재정의 함수는 기본 클래스와 상속 클래스 모두에서 반환 유형 및 여러 매개 변수와 함께 동일한 정의를 가져야 합니다. 이들 중 어느 하나라도 차이점이 있다면 이 기능을 새로운 기능으로 이해하면서 오버라이드 기능으로 간주하지 않을 것입니다.
Java에서 @Override Annotation은 어떻게 작동하나요?
- Override 주석은 상속된 클래스에 정의된 재정의 함수 바로 앞에 사용되어 이 함수가 두 개의 다른 클래스에서 동일한 매개변수와 반환 유형을 사용하여 의도적으로 정의되었음을 컴파일러가 이해할 수 있도록 합니다.
- 함수는 기본 클래스와 상속 클래스 모두에서 동일한 매개변수를 가지므로 어떤 함수를 호출해야 하는지 시스템이 이해하려면 인스턴스를 사용하여 함수를 호출해야 합니다.
- 상위 클래스의 객체를 사용하여 함수를 호출하면 로컬 함수 정의가 포함된 상위 클래스 함수가 호출되고, 상속된 클래스의 객체를 사용하면 상속된 클래스의 함수가 호출됩니다.
예:
Base class {} Child class{} Base object1= new Base();// Here Base class is instantiated so the function definition will be called from base class. Base object2= new Child(); /// Here Child class is instantiated so the function definition will be called from child class
- 이제 위에 정의된 "object1" 및 "object2"라는 개체를 점 연산자와 함께 사용하여 함수 정의를 가져옵니다.
- 이 모든 기능은 실제 코드 실행이 시작되는 메인 클래스에서 유지되는 경우에만 작동합니다.
- 컨트롤이 메인 클래스에 도달한 다음 메인 클래스 위에 미리 정의된 클래스의 객체 인스턴스를 검색합니다.
- 그러면 개체가 호출된 함수를 호출합니다.
- 클래스 정의에 프로토타입으로 이미 정의된 경우 원하는 매개변수를 함수에 전달할 수도 있습니다.
- 하나의 기본 클래스는 둘 이상의 클래스에서 상속될 수 있습니다. 유일한 차이점은 객체 생성과 해당 객체를 사용한 함수 호출입니다.
Java @Override의 예
다음은 예시입니다.
예시 #1
재정의 주석 작업을 보여주는 예
설명:
아래 프로그램에는 두 개의 클래스가 정의되어 있습니다. 하나는 상위 클래스 "Pclass"라고도 하는 기본 클래스이고, 다른 하나는 기본 클래스의 속성과 멤버 함수를 상속하는 클래스 ", Cclass"입니다. 상속된 클래스 또는 자식 클래스라고 합니다. 함수는 먼저 상위 클래스에서 선언됩니다. 이 예제에서는 함수 이름이 printfunction() 이며 매개변수로 전달된 문자열을 인쇄하는 작업을 담당합니다.
같은 이름의 함수가 앞에 @override 주석이 붙은 "Cclass"라는 상속 클래스에 선언되고 정의됩니다. 다른 문자열은 매개변수로 전달됩니다. 메인 클래스에서는 위에서 정의한 클래스가 객체를 생성하여 인스턴스화됩니다. "object1"은 Pclass의 개체를 식별하고 "object2"는 Cclass의 개체를 식별합니다. 이러한 서로 다른 객체를 사용하여 동일한 함수가 호출됩니다. 첫 번째 경우 object1은 상위 클래스인 Pclass에서 문자열을 가져옵니다. 나중에 object2가 호출되면 @override 주석이 실행되고 콘텐츠 문자열이 변경됩니다. 이는 이해하기 쉬운 코드와 더 나은 기능을 위해 Java에서 제공되는 재정의 기능입니다.
코드:
// This is Base class class Pclass { void printfunction() { System.out.println("This is the output of function present in parent class \"Pclass\". "); } } // This is Child class class Cclass extends Pclass { // The below function is override function along with override annotation @Override void printfunction() { System.out.println("This is the output of function present in child class \"Cclass\"."); } } // Thi is Main class from here the contro; execution starts. JAVA compiler searches for main class to start executing any code. public class Main { public static void main(String[] args) { Pclass object1 = new Pclass(); object1.printfunction(); Pclass object2 = new Cclass(); object2.printfunction(); } }
출력:
다음은 두 개의 문자열 라인이 있는 출력 화면입니다. 첫 번째 문자열 줄은 기본 함수에서 나오고, 두 번째 문자열 줄은 상속된 클래스에 정의된 재정의 함수에서 나옵니다.
Example #2
Here we have one base class with two child classes inheriting it. The second inherited class is instantiated, and the output string is triggered from the 2nd inherited class.
Code:
class Pclass { void printfunction() { System.out.println("This is the output of function present in parent class \"Pclass\". "); } } // This is Child class class Cclass extends Pclass { // The below function is override function along with override annotation @Override void printfunction() { System.out.println("This is the output of function present in child class \"Cclass\"."); } } // This is Child class class Cclass2 extends Pclass { // The below function is override function along with override annotation @Override void printfunction() { System.out.println("This is the output of function present in child class number 2 \"Cclass\"."); } } // This is Main class from here the contro; execution starts. JAVA compiler searches for main class to start executing any code. public class Main { public static void main(String[] args) { Pclass object1 = new Pclass(); object1.printfunction(); Pclass object2 = new Cclass2(); object2.printfunction(); } }
Output:
Conclusion
Hence Java override function comes with a lot of benefits like providing run-time polymorphism, easy code access, clean code and many more. Adding override annotation assures that the compiler understands the intention of function definition via function declarations in classes. This is one of the important properties of the oops concept called polymorphism.
위 내용은 자바 @오버라이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

Java는 플랫폼 독립성으로 인해 엔터프라이즈 수준의 응용 프로그램에서 널리 사용됩니다. 1) 플랫폼 독립성은 JVM (Java Virtual Machine)을 통해 구현되므로 JAVA를 지원하는 모든 플랫폼에서 코드가 실행될 수 있습니다. 2) 크로스 플랫폼 배포 및 개발 프로세스를 단순화하여 유연성과 확장 성을 더 많이 제공합니다. 3) 그러나 성능 차이 및 타사 라이브러리 호환성에주의를 기울이고 순수한 Java 코드 사용 및 크로스 플랫폼 테스트와 같은 모범 사례를 채택해야합니다.

javaplaysaSignificantroleiniotduetoitsplatformincentence.1) itallowscodetobewrittenonceandevices.2) java'secosystemprovidesusefullibrariesforiot.3) itssecurityfeaturesenhanceiotiotsystemsafety.hormormory.hormory.hustupletety.houghmormory

thejava.nio.filepackage.1) withsystem.getProperty ( "user.dir") andtherelativeatthereplattHefilePsiple.2) thepathtopilebtoafne 컨버터링 주제

Java'SplatformIndenceSnictIficantIficantBecauseItAllowsDeveloperstowRiteCodeOnceAntOnitonAnyplatformwithajvm.이 "WriteOnce, Runanywhere"(WORA) 접근자 : 1) 교차 플랫폼 컴퓨팅 성, DeploymentAcrossDifferentoSwithoutissswithoutissuesswithoutissuesswithoutswithoutisssues를 활성화합니다

Java는 크로스 서버 웹 응용 프로그램을 개발하는 데 적합합니다. 1) Java의 "Write Once, Run Everywhere"철학은 JVM을 지원하는 모든 플랫폼에서 코드를 실행합니다. 2) Java는 Spring 및 Hibernate와 같은 도구를 포함하여 개발 프로세스를 단순화하는 풍부한 생태계를 가지고 있습니다. 3) Java는 성능 및 보안에서 훌륭하게 성능을 발휘하여 효율적인 메모리 관리 및 강력한 보안 보증을 제공합니다.

JVM은 바이트 코드 해석, 플랫폼 독립 API 및 동적 클래스 로딩을 통해 Java의 Wora 기능을 구현합니다. 1. 바이트 코드는 크로스 플랫폼 작동을 보장하기 위해 기계 코드로 해석됩니다. 2. 표준 API 추상 운영 체제 차이; 3. 클래스는 런타임에 동적으로로드되어 일관성을 보장합니다.

JAVA의 최신 버전은 JVM 최적화, 표준 라이브러리 개선 및 타사 라이브러리 지원을 통해 플랫폼 별 문제를 효과적으로 해결합니다. 1) Java11의 ZGC와 같은 JVM 최적화는 가비지 수집 성능을 향상시킵니다. 2) Java9의 모듈 시스템과 같은 표준 라이브러리 개선은 플랫폼 관련 문제를 줄입니다. 3) 타사 라이브러리는 OpenCV와 같은 플랫폼 최적화 버전을 제공합니다.

JVM의 바이트 코드 검증 프로세스에는 네 가지 주요 단계가 포함됩니다. 1) 클래스 파일 형식이 사양을 준수하는지 확인, 2) 바이트 코드 지침의 유효성과 정확성을 확인하고 3) 유형 안전을 보장하기 위해 데이터 흐름 분석을 수행하고 4) 검증의 철저한 성능 균형을 유지합니다. 이러한 단계를 통해 JVM은 안전하고 올바른 바이트 코드 만 실행되도록하여 프로그램의 무결성과 보안을 보호합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

드림위버 CS6
시각적 웹 개발 도구
