C의 Array.IsSynchronized 속성은 Array에 대한 액세스가 동기화되었는지 여부를 나타내는 값을 가져옵니다. IsSynchronized 속성은 System.Collections.ICollection 인터페이스에 필요하기 때문에 Arrays에 의해 구현됩니다. 배열을 사용하는 클래스는 SyncRoot 속성을 사용하여 자체 동기화를 구현할 수도 있습니다. 다음은 구문입니다 - public bool IsSynchronized { get; } Array.IsSynchronized 속성 구현은 SyncRoot 속성과 동
C#과 Java는 널리 사용되는 객체 지향 프로그래밍 언어입니다. 다음은 C#과 Java의 차이점입니다 - 연산자 과부하 C#은 연산자 오버로딩을 지원하지만 Java에는 연산자 오버로딩이라는 개념이 없습니다. 대리인 C#에는 대리자가 있지만 Java는 이 개념을 지원하지 않습니다. 프로그램 실행 Java에는 JVM(Java Virtual Machine)이 있는 반면 C#에는 CLR(Common Language Runtime)이 있습니다. 조건부 컴파일 C#은 조건부 컴파일을 위해 전처리기 지시문을 사용하지만 Java는 지원하
문자열에 고유한 문자가 있는지 확인하려면 먼저 다음 단어가 있는 문자열의 단어를 확인하십시오 - for (int j = i + 1; j < val.Length; j++) { if (val[i] == val[j]) } 일치하는 항목을 찾으면 문자열에 고유한 문자가 없음을 의미합니다. 일치하는 항목을 찾을 수 없으면 문자열에 고유한 문자가 모두 있는 것입니다. 일치하는 경우 false를 반환합니다. 즉 고유한 문자를 찾을 수 없습니다 - for (int j = i + 1; j < val.Lengt
리플렉션 개체는 런타임에 형식 정보를 얻는 데 사용됩니다. 실행 중인 프로그램의 메타데이터에 대한 액세스를 제공하는 클래스는 System.Reflection 네임스페이스에 있습니다. 다음은 반사의 응용 프로그램입니다 - 런타임에 속성 정보를 볼 수 있습니다. 어셈블리에서 다양한 유형을 검사하고 이러한 유형을 인스턴스화할 수 있습니다. 메소드 및 속성에 대한 후기 바인딩 허용 런타임에 새로운 유형을 생성한 다음 해당 유형을 사용하여 일부 작업을 수행할 수 있습니다. System.Reflection 네임스페이스에는 응용 프로그램
콘솔.ReadKey(); VS.NET 사용자를 위한 것입니다. 이것은 프로그램이 키 누름을 기다리게 하고 프로그램이 Visual Studio .NET에서 시작될 때 화면이 빠르게 실행되고 닫히는 것을 방지합니다. ReadKey() 메서드의 일반적인 용도는 프로그램 실행을 중지할 수 있다는 것입니다. 이것은 사용자가 키를 누를 때까지 수행될 수 있습니다. 예를 들어 보겠습니다 - 예 using System; public class Demo { public static void Main() {
정수 리터럴 정수 리터럴은 10진수 또는 16진수 상수일 수 있습니다. 접두사는 기본 또는 기수(16진수의 경우 0x 또는 0X)를 지정하고 10진수의 경우 접두사 ID가 없습니다. 다음은 정수 리터럴의 몇 가지 예입니다. - 10 // int 18u // unsigned int 변수를 선언하고 초기화하는 동안 위의 리터럴을 사용합시다 - // int int a =10; 이제 값을 인쇄합니다 - 예시 using System; namespace Demo { class Program { &nb
제네릭을 사용하면 모든 데이터 유형에서 작동할 수 있는 클래스 또는 메서드를 작성할 수 있습니다. 유형 매개변수를 사용하여 일반 메소드 선언 - static void Swap(ref T lhs, ref T rhs) {} 위에 표시된 제네릭 메서드를 호출하기 위한 예는 다음과 같습니다. - Swap(ref a, ref b); C#에서 제네릭 메서드를 만드는 방법을 살펴보겠습니다 − 예 using System; using System.Collections.Generic; namespace Demo { cla
C#의 HashSet은 배열의 중복 문자열이나 요소를 제거합니다. C#에서는 최적화된 집합 모음입니다. C# HashSet을 사용하여 중복 문자열을 제거하는 예를 살펴보겠습니다. 여기에 중복 요소가 있습니다 - 예시 using System; using System.Collections.Generic; using System.Linq; class Program { static void Main() { string[] arr1 = {
C#은 Anders Hejlsberg가 이끄는 .NET 이니셔티브 내에서 Microsoft에서 개발한 단순하고 현대적인 범용 개체 지향 프로그래밍 언어입니다. C++는 1979년 Bell Labs에서 시작하여 Bjarne Stroustrup이 개발한 중간 수준 프로그래밍 언어입니다. C++는 Windows, Mac OS 및 다양한 UNIX 버전과 같은 다양한 플랫폼에서 실행됩니다. 다음은 C#에서 누락된 C++의 일부 기능입니다 - C#에서는 다중 상속이 불가능하지만 C++에서는 다중 상속을 쉽게 구현할 수 있습니다.
Array.SyncRoot 속성은 Array에 대한 액세스를 동기화하는 데 사용할 수 있는 개체를 가져오는 데 사용됩니다. 배열이 있는 클래스는 SyncRoot 속성을 사용하여 자체 동기화를 구현할 수도 있습니다. 컬렉션을 통해 열거하는 것은 스레드로부터 안전한 절차가 아닙니다. 다른 스레드는 컬렉션이 동기화된 경우에도 컬렉션을 수정할 수 있습니다. 이로 인해 결국 열거자가 예외를 throw합니다. 이를 위해서는 컬렉션을 잠가야 합니다. Array.SyncRoot 속성으로 작업하는 예를 살펴보겠습니다 - 예시 using Syst
순환 참조는 둘 이상의 상호 의존적인 리소스가 잠금 조건을 유발할 때 발생합니다. 리소스를 사용할 수 없게 됩니다. C#에서 순환 참조 문제를 처리하려면 가비지 수집을 사용해야 합니다. 순환 참조를 감지하고 수집합니다. 가비지 수집기는 로컬 및 정적으로 시작하며 자식을 통해 도달할 수 있는 각 개체를 표시합니다. 이를 통해 순환 참조 문제를 처리할 수 있습니다. 다음 클래스가 순환 참조에 있다고 가정해 보겠습니다. 여기서 둘은 서로 의존합니다 - public class A { B Two; } publi
using 문은 하나 이상의 리소스를 설정하는 데 사용됩니다. 이러한 리소스가 실행되고 리소스가 해제됩니다. 이 명령문은 데이터베이스 작업에도 사용됩니다. 주요 목표는 리소스를 관리하고 모든 리소스를 자동으로 해제하는 것입니다. SystemResource가 먼저 할당되므로 A가 먼저 인쇄되는 예를 살펴보겠습니다. 예 using System; using System.Text; class Demo { static void Main() { using (SystemResou
제네릭을 사용하면 프로그램에서 실제로 사용될 때까지 클래스나 메서드에 있는 프로그래밍 요소의 데이터 유형 지정을 지연할 수 있습니다. 즉, 제네릭을 사용하면 모든 데이터 유형에서 작동할 수 있는 클래스 또는 메서드를 작성할 수 있습니다. 다음은 C#에서 제네릭의 기능입니다 − 특정 데이터 유형의 메서드에 액세스할 수 있도록 제한된 일반 클래스를 만듭니다. 리플렉션을 통해 런타임에 일반 데이터 형식에 사용된 형식에 대한 정보를 가져옵니다. 코드 재사용, 유형 안전성 및 성능을 극대화합니다. .NET Framew
문자열 리터럴 또는 상수는 큰따옴표 또는 @로 묶입니다. 문자열에는 일반 문자, 이스케이프 시퀀스 및 범용 문자와 같은 문자 리터럴과 유사한 문자가 포함됩니다. 다음은 문자열 리터럴의 몇 가지 예입니다. - “Hi, User" "You’re Welcome, \ 다음은 문자열 리터럴의 사용법을 보여주는 예입니다 - 예 using System; namespace Demo { class Program { static void Ma
부동 소수점 리터럴에는 정수 부분, 소수점, 소수 부분 및 지수 부분이 있습니다. 부동 소수점 리터럴은 10진수 형식이나 지수 형식으로 나타낼 수 있습니다. 다음은 부동 소수점 리터럴의 몇 가지 예입니다. - 9.23456 269485E-5F 이제 부동 소수점 리터럴을 인쇄해 보겠습니다 - 예 using System; namespace Demo { class Program { static void Main(string[] args) {
인덱서를 사용하면 배열과 같은 개체를 인덱싱할 수 있습니다. 구문을 보자 - element-type this[int index] { // The get accessor. get { // return the value specified by index } // The set accessor. set { // set the value specif
System.IO 네임스페이스에는 파일 생성 및 삭제, 파일 읽기 또는 쓰기, 파일 닫기 등과 같은 파일에 대한 다양한 작업을 수행하는 데 유용한 다양한 클래스가 있습니다. 다음은 C#의 I/O 클래스입니다 − 시니어 번호 I/O 클래스 및 설명 1 BinaryReader 바이너리 스트림에서 기본 데이터를 읽습니다. 2 BinaryWriter 기본 데이터를 바이너리 형식으로 씁니다. 3 BufferedStream 바이트 스트림을 위한 임시 저장소입니다. 4 디렉토리 디렉토리 구조를 조작하는 데 도움이 됩
먼저 사전을 만들어 보겠습니다 − var d = new Dictionary<string, int>(5); 이제 키와 값을 추가하십시오 - // add key and value d.Add("car", 25); d.Add("bus", 28); d.Add("motorbike", 17); 값을 기준으로 정렬하려면 orderby를 사용하세요 - var val = from ele in d orderby ele.Value ascending select ele; 사전을 오름차순
C#의 일반 컬렉션에는 , 등이 포함됩니다. 목록 List는 일반 컬렉션이고 ArrayList는 일반 컬렉션이 아닙니다. 예를 들어 보겠습니다. 여기 목록에 6개의 요소가 있습니다. - 예시 using System; using System.Collections.Generic; class Program { static void Main() { // Initializing collections List myList = new Li
일반 대리자를 사용하면 대리자 문을 정의할 필요가 없습니다. 시스템 네임스페이스에 정의되어 있습니다. 형식 매개 변수를 사용하여 제네릭 대리자를 정의할 수 있습니다. 예를 들어 - delegate T myDelegete<T>(T n); 예 다음은 C#에서 일반 대리자를 만드는 방법을 보여주는 예입니다 - using System; using System.Collections.Generic; delegate T myDelegete<T>(T n); namespace GenericDelegateAppl { &nb