CType 함수(Visual Basic)

특정 식을 지정된 데이터 형식, 개체, 구조, 클래스 또는 인터페이스로 명시적으로 변환한 결과를 반환합니다.

CType(expression, typename)

구성 요소

  • expression
    임의의 유효한 식입니다. expression 값이 typename에서 허용되는 범위를 벗어나면 Visual Basic에서 예외가 throw됩니다.

  • typename
    Dim 문의 As 절에서 유효한 임의의 식, 즉 임의의 데이터 형식, 개체, 구조체, 클래스 또는 인터페이스 이름입니다.

설명

CType은 인라인으로 컴파일됩니다. 즉, 변환 코드가 식을 계산하는 코드의 일부입니다. 실행을 더욱 빠르게 만드는 변환을 수행하기 위한 프로시저 호출이 없는 경우도 있습니다.

expression에서 typename으로(예: Integer에서 Date로)의 변환이 정의되어 있지 않으면 Visual Basic에서 컴파일 타임 오류 메시지가 표시됩니다.

런타임에 변환이 실패하면 해당 예외가 발생합니다. 축소 변환이 실패할 경우에는 OverflowException이 가장 많이 발생합니다. 변환이 정의되지 않으면 InvalidCastException이 발생합니다. 예를 들어, expression이 Object 형식이고 해당 런타임 형식이 typename으로 변환되지 않을 경우에 이러한 결과가 발생합니다.

expression 또는 typename의 데이터 형식이 사용자가 정의한 클래스나 구조체이면 해당 클래스나 구조체에 대해 CType을 변환 연산자로 정의할 수 있습니다. 이렇게 하면 CType은 오버로드된 연산자 기능을 합니다. 이때 throw될 수 있는 예외를 비롯하여 클래스나 구조체에 대한 변환 동작을 제어할 수 있습니다.

오버로딩

CType 연산자는 코드 외부에서 정의된 클래스나 구조체에 대해서도 오버로드될 수 있습니다. 그러한 클래스나 구조체와 코드 간의 변환을 수행할 때는 해당 CType 연산자의 동작을 알고 있어야 합니다. 자세한 내용은 연산자 프로시저(Visual Basic)을 참조하십시오.

동적 개체 변환

형식 변환이 TryConvert 또는 BindConvert 메서드를 사용하는 사용자 정의 동적 변환에 의해 수행되는 동적 개체에서 작업하는 경우 CTypeDynamic 메서드를 사용하여 동적 개체를 변환합니다.

예제

다음 예제에서는 CType 함수를 사용하여 식을 지정된 데이터 형식으로 변환합니다.

Dim testNumber As Long = 1000
' The following line of code sets testNewType to 1000.0.
Dim testNewType As Single = CType(testNumber, Single)

참고 항목

작업

방법: 변환 연산자 정의(Visual Basic)

참조

형식 변환 함수(Visual Basic)

변환 함수(Visual Basic)

OverflowException

InvalidCastException

Operator 문