인스턴스 메서드가 앞에 virtual 키워드로 선언된 경우 이 메서드는 가상 메서드입니다.
가상 메서드와 비가상 메서드의 가장 큰 차이점은 가상 메서드의 구현이 파생 클래스로 대체될 수 있다는 것입니다. 이러한 대체는 메서드를 다시 작성하여 수행됩니다(자세한 내용은 나중에 설명).
가상 메서드의 특징:
가상 메서드 앞에는 static, abstract, override 수식자가 허용되지 않습니다
가상 메서드는 private이 될 수 없으므로 private 수식어를 사용할 수 없습니다
가상 메서드 실행:
일반 함수가 컴파일되는 것으로 알고 있습니다. 컴파일 타임에 실행 파일로 정적으로 컴파일되며, 프로그램 실행 중에 상대 주소가 변경되지 않습니다.
그리고 가상 함수는 컴파일 중에 정적으로 컴파일되지 않습니다. on 런타임 객체 인스턴스는 호출할 함수를 동적으로 결정하는 데 사용됩니다.
선언 중에 정의된 클래스를 선언 클래스라고 하며, 실행 중에 인스턴스화되는 클래스를 인스턴스 클래스라고 합니다.
예: A a =new B(); 여기서 A는 선언 클래스이고 B는 인스턴스 클래스입니다.
1. 객체의 함수를 호출할 때 시스템은 객체가 선언한 클래스, 즉 선언된 클래스를 직접 확인하여 호출된 함수가 가상 함수인지 확인합니다.
2. 가상 함수가 아닌 경우 함수를 직접 실행합니다. 그리고 가상 함수라면 이때 바로 함수를 실행하지 않고 객체의 인스턴스 클래스를 확인하기 시작합니다.
3. 이 인스턴스 클래스에서는 인스턴스 클래스의 정의에 가상 함수를 구현하거나 (override 키워드를 통해) 가상 함수를 다시 구현하는 방법이 있는지 확인합니다.
, 다시 찾아보는 것이 아니라 인스턴스 클래스에 구현된 가상 함수의 메소드를 즉시 실행합니다. 그렇지 않은 경우 시스템은 인스턴스 클래스의 상위 클래스
를 계속 검색하고 지금까지 가상 함수를 오버로드한 첫 번째 상위 클래스를 찾을 때까지 인스턴스 클래스에서 확인을 반복한 다음 실행합니다. 상위 클래스의 오버로드된 함수.
예제 1:
class A { public virtual void Sum() { Console.WriteLine("I am A Class,I am virtual sum()."); } } class Program { static void Main(string[] args) { A a=new A(); // 定义一个a这个A类的对象.这个A就是a的申明类,实例化a对象,A是a的实例类 a.Sum(); Console.Read(); } }
a.Sum 실행:
1. 먼저 선언 클래스 A를 확인합니다. 2. sum이 가상 메소드인지 확인합니다. 3. 인스턴스 클래스 A를 확인합니다. 결과는 질문 그 자체입니다
4. 인스턴스 클래스 A에서 Sum을 구현하는 메서드를 실행합니다. 5. 결과를 출력합니다. I am A Class, I am virtual sum()
예 2:
class A { public virtual void Sum() { Console.WriteLine("I am A Class,I am virtual sum()."); } } class B : A { public override void Sum() // 重新实现了虚函数 { Console.WriteLine("I am B Class,I am override sum()."); } } class Program { static void Main(string[] args) { A a=new B(); // 定义一个a这个A类的对象.这个A就是a的申明类,实例化a对象,B是a的实例类 a.Sum(); Console.Read(); } }
실행 a. 합:
1. 먼저 선언 클래스 A를 확인합니다. 2. 가상 메서드인지 확인합니다. 3. 인스턴스 클래스 B를 확인하면 재정의된 메서드가 있습니다. 4. 해당 메서드를 실행합니다. 인스턴스 클래스 B 5. 결과 출력 I am B Class ,I am override sum().
예 3:
class A { public virtual void Sum() { Console.WriteLine("I am A Class,I am virtual sum()."); } } class B : A { public override void Sum() // 重新实现了虚函数 { Console.WriteLine("I am B Class,I am override sum()."); } } class C : B { } class Program { static void Main(string[] args) { A a=new C();// 定义一个a这个A类的对象.这个A就是a的申明类,实例化a对象,C是a的实例类 a.Sum(); Console.Read(); } }
a.Sum 실행:
1. 먼저 선언 클래스를 확인하세요. A 2. 가상 메소드인지 확인 3. 인스턴스 클래스 C 확인으로 이동, 재정의된 메서드 없음 4. 클래스 C의 상위 클래스 B 확인으로 이동, 재정의된 메서드 있음
5. Sum 메서드 실행 상위 클래스 B 6. 결과 출력 I am B Class, I am override sum()
예 4:
class A { public virtual void Sum() { Console.WriteLine("I am A Class,I am virtual sum()."); } } class B : A { public new void Sum() //覆盖父类里的同名函数,而不是重新实现 { Console.WriteLine("I am B Class,I am new sum()."); } } class Program { static void Main(string[] args) { A a=new B(); a.Sum(); Console.Read(); } }
a.Sum 실행:
1. class A 2. 가상 메서드인지 확인합니다. 3. 재정의하지 않고 인스턴스 클래스 B 를 확인합니다. (여기서 Sum() 은 B에서 구현되었지만 override 키워드는 사용되지 않으므로 a로 간주되지 않습니다. 재작성) 4. 클래스 B의 상위 클래스 A를 확인한 다음 자체적으로 5. 상위 클래스 A에서 Sum 메소드를 실행합니다. 6. 결과를 출력합니다. I am A Class, I am virtual sum()
그래서. 예제 4에서 클래스 B가 선언되면 어떻게 될까요?
class A { public virtual void Sum() { Console.WriteLine("I am A Class,I am virtual sum()."); } } class B : A { public new void Sum() //覆盖父类里的同名函数,而不是重新实现 { Console.WriteLine("I am B Class,I am new sum()."); } } class Program { static void Main(string[] args) { B b=new B(); b.Sum(); Console.Read(); } }
클래스 B에서 Sum()을 실행하고 결과를 출력합니다. I am B Class, I am new sum()
추상 함수를 사용하여 기본 클래스의 가상 함수를 재정의할 수 있나요?
답은 '그렇다'입니다.
class A { public virtual void PrintFriends() { Console.WriteLine("A.PrintFriends()"); } } abstract class B : A { public abstract override void PrintFriends(); //使用override 修饰符,表示抽象重写了基类中该函数的实现 } abstract class C : A { public abstract new void PrintFriends(); //使用 new 修饰符显式声明,表示隐藏了基类中该函数的实现 }
봉인 클래스에 가상 기능이 포함될 수 있나요?
예, 기본 클래스의 가상 함수는 암시적으로 비가상 함수로 변환되지만 봉인된 클래스 자체는 새 가상 함수를 추가할 수 없습니다.
class A { public virtual void Fun() { Console.WriteLine("I am A."); } } sealed class Program:A { public override void Fun() { Console.WriteLine("I am B."); } static void Main(string[] args) { Program p = new Program(); p.Fun(); Console.Read(); } }

C#과 .NET의 관계는 분리 할 수 없지만 같은 것은 아닙니다. C#은 프로그래밍 언어이며 .NET은 개발 플랫폼입니다. C#은 코드를 작성하고 .NET의 중간 언어 (IL)로 컴파일하고 .NET 런타임 (CLR)에 의해 실행되는 데 사용됩니다.

C#.NET은 여러 응용 프로그램 개발을 지원하는 강력한 도구 및 라이브러리를 제공하기 때문에 여전히 중요합니다. 1) C#은 .NET 프레임 워크를 결합하여 개발 효율적이고 편리하게 만듭니다. 2) C#의 타입 안전 및 쓰레기 수집 메커니즘은 장점을 향상시킵니다. 3) .NET은 크로스 플랫폼 실행 환경과 풍부한 API를 제공하여 개발 유연성을 향상시킵니다.

C#.NETISVERSATILEFORBOTHWEBBANDDESKTOPDEVENTROMMENT.1) FORWEB, useASP.NETFORRICHINTERFACES.3) FORDESKTOP.3) USEXAMARINFORCROSS-PLATFORMDEEVENTRIMMENT, LINABILEDEV, MACODEDEV, and MACODEDOWS, 및 MACODEDOWS.

C# 및 .NET는 지속적인 업데이트 및 최적화를 통해 신흥 기술의 요구에 적응합니다. 1) C# 9.0 및 .NET5는 레코드 유형 및 성능 최적화를 소개합니다. 2) .NETCORE는 클라우드 네이티브 및 컨테이너화 된 지원을 향상시킵니다. 3) ASP.NETCORE는 최신 웹 기술과 통합됩니다. 4) ML.NET는 기계 학습 및 인공 지능을 지원합니다. 5) 비동기 프로그래밍 및 모범 사례는 성능을 향상시킵니다.

C#.netissuitable forenterprise-levelapplications는 richlibraries, androbustperformance, 그러나 itmaynotbeidealforcross-platformdevelopmentorwhenrawspeediscritical, wherelanguagesslikerustorthightordogrordogrognegrognegrognegrognecross-platformdevelopmentor.

.NET에서 C#의 프로그래밍 프로세스에는 다음 단계가 포함됩니다. 1) C# 코드 작성, 2) 중간 언어 (IL)로 컴파일하고 .NET 런타임 (CLR)에 의해 실행됩니다. .NET에서 C#의 장점은 현대적인 구문, 강력한 유형 시스템 및 .NET 프레임 워크와의 긴밀한 통합으로 데스크탑 응용 프로그램에서 웹 서비스에 이르기까지 다양한 개발 시나리오에 적합합니다.

C#은 Microsoft가 개발 한 최신 객체 지향 프로그래밍 언어이며 .NET 프레임 워크의 일부로 개발되었습니다. 1.C#은 캡슐화, 상속 및 다형성을 포함한 객체 지향 프로그래밍 (OOP)을 지원합니다. 2. C#의 비동기 프로그래밍은 응용 프로그램 응답 성을 향상시키기 위해 비동기 및 키워드를 기다리는 키워드를 통해 구현됩니다. 3. LINQ를 사용하여 데이터 컬렉션을 간결하게 처리하십시오. 4. 일반적인 오류에는 NULL 참조 예외 및 인덱스 외 예외가 포함됩니다. 디버깅 기술에는 디버거 사용 및 예외 처리가 포함됩니다. 5. 성능 최적화에는 StringBuilder 사용 및 불필요한 포장 및 Unboxing을 피하는 것이 포함됩니다.

C#.NET 애플리케이션에 대한 테스트 전략에는 단위 테스트, 통합 테스트 및 엔드 투 엔드 테스트가 포함됩니다. 1. 단위 테스트를 통해 MSTEST, NUNIT 또는 XUNIT 프레임 워크를 사용하여 코드의 최소 단위가 독립적으로 작동합니다. 2. 통합 테스트는 일반적으로 사용되는 시뮬레이션 된 데이터 및 외부 서비스를 결합한 여러 장치의 기능을 확인합니다. 3. 엔드 투 엔드 테스트는 사용자의 완전한 작동 프로세스를 시뮬레이션하며 셀레늄은 일반적으로 자동 테스트에 사용됩니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

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

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

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