C #-전 처리기 지시문
전 처리기 지시문은 실제 컴파일이 시작되기 전에 정보를 전처리하라는 지시를 컴파일러에 제공합니다.
모든 전 처리기 지시문은 #으로 시작하며 한 줄의 전 처리기 지시문 앞에 공백 문자 만 나타날 수 있습니다. 전 처리기 지시문은 명령문이 아니므로 세미콜론 (;)으로 끝나지 않습니다.
C # 컴파일러에는 별도의 전처리 기가 없습니다. 그러나 지시문은 마치 하나가있는 것처럼 처리됩니다. C #에서 전 처리기 지시문은 조건부 컴파일을 지원하는 데 사용됩니다. C 및 C ++ 지시문과 달리 매크로를 만드는 데 사용되지 않습니다. 전 처리기 지시문은 한 줄의 유일한 명령이어야합니다.
C #의 전 처리기 지시문
다음 표는 C #에서 사용할 수있는 전 처리기 지시문을 나열합니다.
Sr. 아니. | 전 처리기 지시문 및 설명 |
---|---|
1 | #define 기호라고하는 일련의 문자를 정의합니다. |
2 | #undef 심볼을 정의 해제 할 수 있습니다. |
삼 | #if 이를 통해 기호 또는 기호를 테스트하여 참으로 평가되는지 확인할 수 있습니다. |
4 | #else #if와 함께 복합 조건부 지시문을 만들 수 있습니다. |
5 | #elif 복합 조건부 지시문을 만들 수 있습니다. |
6 | #endif 조건부 지시문의 끝을 지정합니다. |
7 | #line 이를 통해 컴파일러의 줄 번호와 오류 및 경고에 대한 파일 이름 출력 (선택 사항)을 수정할 수 있습니다. |
8 | #error 코드의 특정 위치에서 오류를 생성 할 수 있습니다. |
9 | #warning 코드의 특정 위치에서 레벨 1 경고를 생성 할 수 있습니다. |
10 | #region Visual Studio 코드 편집기의 개요 기능을 사용할 때 확장하거나 축소 할 수있는 코드 블록을 지정할 수 있습니다. |
11 | #endregion #region 블록의 끝을 표시합니다. |
#define 전 처리기
#define 전 처리기 지시문은 기호 상수를 만듭니다.
#define을 사용하면 #if 지시문에 전달 된 식으로 기호를 사용하여식이 true로 평가되도록 기호를 정의 할 수 있습니다. 구문은 다음과 같습니다.
#define symbol
다음 프로그램은 이것을 설명합니다-
#define PI
using System;
namespace PreprocessorDAppl {
class Program {
static void Main(string[] args) {
#if (PI)
Console.WriteLine("PI is defined");
#else
Console.WriteLine("PI is not defined");
#endif
Console.ReadKey();
}
}
}
위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.
PI is defined
조건부 지시문
#if 지시문을 사용하여 조건부 지시문을 만들 수 있습니다. 조건부 지시문은 기호가 참인지 확인하기 위해 기호를 테스트하는 데 유용합니다. true로 평가되면 컴파일러는 #if와 다음 지시문 사이의 모든 코드를 평가합니다.
조건부 지시문의 구문은-
#if symbol [operator symbol]...
여기서 symbol 은 테스트 할 기호의 이름입니다. true 및 false를 사용하거나 기호 앞에 부정 연산자를 추가 할 수도 있습니다.
연산자 심볼 심볼을 평가하기 위해 사용되는 연산자이다. 연산자는 다음 중 하나 일 수 있습니다.
- == (같음)
- ! = (같지 않음)
- && (및)
- || (또는)
괄호로 기호와 연산자를 그룹화 할 수도 있습니다. 조건부 지시문은 디버그 빌드 용 코드를 컴파일하거나 특정 구성 용으로 컴파일 할 때 사용됩니다. 로 시작하는 조건부 지시문#if 지시문은 명시 적으로 #endif 지령.
다음 프로그램은 조건부 지시문의 사용을 보여줍니다-
#define DEBUG
#define VC_V10
using System;
public class TestClass {
public static void Main() {
#if (DEBUG && !VC_V10)
Console.WriteLine("DEBUG is defined");
#elif (!DEBUG && VC_V10)
Console.WriteLine("VC_V10 is defined");
#elif (DEBUG && VC_V10)
Console.WriteLine("DEBUG and VC_V10 are defined");
#else
Console.WriteLine("DEBUG and VC_V10 are not defined");
#endif
Console.ReadKey();
}
}
위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.
DEBUG and VC_V10 are defined