문서를 영문으로 보려면 영문 확인란을 선택하세요. 마우스 포인터를 텍스트 위로 이동시켜 팝업 창에서 영문 텍스트를 표시할 수도 있습니다.
번역
영문

Visual Basic의 문

Visual Basic의 문은 완전한 명령이며 키워드, 연산자, 변수, 상수 및 식을 포함할 수 있습니다. 각 문은 다음 범주 중 하나에 속합니다.

  • 선언문. 변수, 상수 또는 프로시저의 이름을 지정하고 데이터 형식도 지정할 수 있습니다.

  • 실행문. 작업을 시작합니다. 이러한 문은 메서드나 함수를 호출할 수 있으며 코드 블록에서 반복하거나 분기할 수 있습니다. 실행문은 값 또는 식을 변수나 상수에 할당하는 할당문을 포함합니다.

이 항목에서는 각 범주에 대해 설명합니다. 또한 한 줄에 여러 문을 결합하는 방법과 하나의 문을 여러 줄에 표시하는 방법에 대해 설명합니다.

선언문을 사용하여 프로시저, 변수, 속성, 배열 및 상수를 정의하고 이름을 지정할 수 있습니다. 프로그래밍 요소를 선언할 때는 해당 데이터 형식, 액세스 수준 및 범위도 정의할 수 있습니다. 자세한 내용은 선언된 요소 특성(Visual Basic)을 참조하십시오.

다음 예제에는 세 가지 선언이 포함되어 있습니다.


Public Sub applyFormat()
    Const limit As Integer = 33
    Dim thisWidget As New widget
    ' Insert code to implement the procedure.
End Sub


첫 번째 선언은 Sub 문입니다. 짝이 되는 End Sub 문과 함께 해당 문은 applyFormat이라는 프로시저를 선언합니다. 또한 applyFormatPublic으로 지정하며 이는 해당 프로시저를 참조할 수 있는 모든 코드에서 이 프로시저를 호출할 수 있음을 의미합니다.

두 번째 선언은 Const 문이며 limit 상수를 선언하여 Integer 데이터 형식과 값 33을 지정합니다.

세 번째 선언은 Dim 문이며 thisWidget 변수를 선언합니다. 데이터 형식은 특정 개체 즉, Widget 클래스에서 생성된 개체입니다. 현재 사용 중인 응용 프로그램에 노출된 모든 기본 데이터 형식이나 개체 형식으로 변수를 선언할 수 있습니다.

초기 값

선언문을 포함하는 코드를 실행하면 Visual Basic에서는 선언된 요소에 필요한 메모리를 예약합니다. 요소에 값이 있는 경우 Visual Basic에서는 해당 값을 해당 데이터 형식의 기본값으로 초기화합니다. 자세한 내용은 Dim 문(Visual Basic)의 "동작"을 참조하십시오.

다음 예제와 같이 선언의 일부로 초기 값을 변수에 할당할 수 있습니다.


Dim m As Integer = 45
' The preceding declaration creates m and assigns the value 45 to it.


변수가 개체 변수인 경우 다음 예제와 같이 New 연산자(Visual Basic) 키워드를 사용하여 선언하면 해당 클래스의 인스턴스를 명시적으로 만들 수 있습니다.


Dim f As New System.Windows.Forms.Form()


선언문에서 지정한 초기 값은 실행이 해당 선언문에 도달하기 전에는 변수에 할당되지 않으며 변수는 값을 할당 받기 전까지 해당 데이터 형식에 대한 기본값을 포함합니다.

실행문은 작업을 실행합니다. 프로시저 호출, 코드에서 다른 위치로 분기, 여러 문 순환, 식 계산 등을 수행할 수 있습니다. 할당문은 실행문의 특수한 경우입니다.

다음 예제에서는 If...Then...Else 제어 구조를 사용하여 변수 값을 기반으로 다른 코드 블록을 실행합니다. 코드의 각 블록 내에서 For...Next 루프는 지정된 횟수만큼 실행됩니다.


Public Sub startWidget(ByVal aWidget As widget,
    ByVal clockwise As Boolean, ByVal revolutions As Integer)
    Dim counter As Integer
    If clockwise = True Then
        For counter = 1 To revolutions
            aWidget.spinClockwise()
        Next counter
    Else
        For counter = 1 To revolutions
            aWidget.spinCounterClockwise()
        Next counter
    End If
End Sub


위의 예제에서 If 문은 clockwise 매개 변수의 값을 확인합니다. 값이 True이면 aWidgetspinClockwise 메서드를 호출하고 값이 False이면 aWidgetspinCounterClockwise 메서드를 호출합니다. If...Then...Else 제어 구조는 End If로 끝납니다.

각 블록 내의 For...Next 루프는 revolutions 매개 변수 값과 같은 횟수만큼 해당 메서드를 호출합니다.

할당문은 할당 연산을 수행합니다. 다음 예제에서와 같이 할당 연산은 할당 연산자(=)의 오른쪽에 있는 값을 왼쪽에 있는 요소에 저장합니다.


v = 42


위의 예제에서 할당문은 리터럴 값 42를 변수 v에 저장합니다.

적합한 프로그래밍 요소

할당 연산자의 왼쪽에 있는 프로그래밍 요소는 값을 받아 저장할 수 있어야 합니다. 즉, ReadOnly(Visual Basic)가 아닌 변수나 속성 또는 배열 요소여야 합니다. 할당문의 컨텍스트에서 이러한 요소의 "왼쪽 값"을 lvalue라고도 합니다.

할당 연산자의 오른쪽에 있는 값은 식에 의해 생성되며 이러한 값은 리터럴, 상수, 변수, 속성, 배열 요소, 기타 식 또는 함수 호출의 조합이 될 수 있습니다. 다음은 이에 대한 예입니다.


x = y + z + findResult(3)


위의 예제에서는 y 변수에 저장된 값을 z 변수에 저장된 값에 추가한 다음 호출에서 반환된 값을 findResult 함수에 추가합니다. 그런 다음 이 식의 전체 값을 x 변수에 저장합니다.

할당문의 데이터 형식

다음 예제에서와 같이 할당 연산자는 숫자 값 외에 String 값도 할당할 수 있습니다.


Dim a, b As String
a = "String variable assignment"
b = "Con" & "cat" & "enation"
' The preceding statement assigns the value "Concatenation" to b.


또한 다음 예제에서와 같이 Boolean 리터럴 또는 Boolean 식을 사용하여 Boolean 값을 할당할 수 있습니다.


Dim r, s, t As Boolean
r = True
s = 45 > 1003
t = 45 > 1003 Or 45 > 17
' The preceding statements assign False to s and True to t.


마찬가지로 Char, Date 또는 Object 데이터 형식의 프로그래밍 요소에 적절한 값을 할당할 수 있습니다. 또한 인스턴스가 만들어진 클래스로 선언된 요소에 개체 인스턴스를 할당할 수 있습니다.

복합 할당문

복합 할당문은 식을 프로그래밍 요소에 할당하기 전에 먼저 해당 식에 대해 연산을 수행합니다. 다음 예제에서는 이러한 연산자 중 하나인 += 연산자를 보여 줍니다. 이 연산자는 오른쪽에 있는 식의 값을 기준으로 연산자의 왼쪽에 있는 변수의 값을 증가시킵니다.


n += 1


위의 예제에서는 n 값에 1을 더한 다음 새 값을 n에 저장합니다. 이것은 다음 문과 동일합니다.


n = n + 1


이 형식의 연산자를 사용하여 다양한 복합 할당 연산을 수행할 수 있습니다. 이러한 연산자에 대한 자세한 내용 및 목록은 할당 연산자(Visual Basic)를 참조하십시오.

다음 예제에서와 같이 기존에 이미 있는 문자열의 끝에 문자열을 추가하는 경우 연결 할당 연산자(&=)가 유용합니다.


Dim q As String = "Sample "
q &= "String"
' q now contains "Sample String".


할당문의 형식 변환

변수, 속성 또는 배열 요소에 할당하는 값은 해당 대상 요소에 적합한 데이터 형식이어야 합니다. 일반적으로 대상 요소의 데이터 형식과 동일한 데이터 형식의 값을 생성하는 것이 좋습니다. 그러나 일부 형식은 할당을 수행하는 동안 다른 형식으로 변환될 수 있습니다.

데이터 형식 변환에 대한 자세한 내용은 Visual Basic의 형식 변환을 참조하십시오. 간단히 요약하면, Visual Basic에서는 지정된 형식의 값을 해당 형식이 확대 변환되는 다른 형식으로 변환합니다. 확대 변환은 런타임에 항상 성공하며 이로 인해 데이터가 손실되지 않습니다. 예를 들어, IntegerDouble로 확대 변환되므로 Visual Basic에서는 해당되는 경우 Integer 값을 Double로 확대 변환합니다. 자세한 내용은 확대 변환과 축소 변환(Visual Basic)을 참조하십시오.

축소 변환(확대 변환되지 않는 변환)은 런타임에 실패할 수 있으며 이로 인해 데이터가 손실될 수 있습니다. 형식 변환 함수를 사용하여 명시적으로 축소 변환을 수행하거나 Option Strict Off를 설정하여 컴파일러가 모든 변환을 암시적으로 수행하도록 할 수 있습니다. 자세한 내용은 암시적 변환과 명시적 변환(Visual Basic)을 참조하십시오.

콜론(:) 문자로 구분하여 한 줄에 여러 개의 문을 포함할 수 있습니다. 다음은 이에 대한 예입니다.


Dim sampleString As String = "Hello World" : MsgBox(sampleString)


이런 형식의 구문을 사용하면 편리할 때도 있지만 코드를 읽고 유지 관리하기가 어려워집니다. 따라서 한 줄에 한 개의 문을 두는 것이 좋습니다.

일반적으로 문은 한 줄에 맞지만 문이 너무 긴 경우에는 줄 연속 시퀀스를 사용하여 다음 줄에서 문을 계속 작성할 수 있습니다. 줄 연속 시퀀스는 공백, 밑줄(_), 캐리지 리턴 순으로 구성되어 있습니다. 다음 예제에서 MsgBox 실행문은 두 줄에 걸쳐 계속됩니다.


Public Sub demoBox()
    Dim nameVar As String
    nameVar = "John"
    MsgBox("Hello " & nameVar _
        & ". How are you?")
End Sub


암시적 줄 연속

대부분의 경우 밑줄 문자(_)를 사용하지 않아도 연속된 다음 줄에서 문을 계속할 수 있습니다. 다음 표에서는 암시적으로 다음 코드 줄에서 문을 계속하는 구문 요소를 나열합니다.

구문 요소

예제

쉼표(,) 뒤


Public Function GetUsername(ByVal username As String,
                            ByVal delimiter As Char,
                            ByVal position As Integer) As String

    Return username.Split(delimiter)(position)
End Function


여는 괄호(() 뒤 또는 닫는 괄호()) 앞


Dim username = GetUsername(
    Security.Principal.WindowsIdentity.GetCurrent().Name,
    CChar("\"),
    1
  )


여는 중괄호({) 뒤 또는 닫는 중괄호(}) 앞


Dim customer = New Customer With {
  .Name = "Terry Adams",
  .Company = "Adventure Works",
  .Email = "terry@www.adventure-works.com"
}


자세한 내용은 개체 이니셜라이저: 명명된 형식과 익명 형식(Visual Basic) 또는 컬렉션 이니셜라이저 개요(Visual Basic)를 참조하십시오.

XML 리터럴 내에서 포함 식 열기(<%=) 뒤 또는 포함 식 닫기(%>) 앞


Dim customerXml = <Customer>
                      <Name>
                          <%=
                              customer.Name
                          %>
                      </Name>
                      <Email>
                          <%=
                              customer.Email
                          %>
                      </Email>
                  </Customer>


자세한 내용은 XML의 포함 식(Visual Basic)을 참조하십시오.

연결 연산자(&) 뒤


cmd.CommandText = 
    "SELECT * FROM Titles JOIN Publishers " &
    "ON Publishers.PubId = Titles.PubID " &
    "WHERE Publishers.State = 'CA'"


자세한 내용은 기능별 연산자 목록(Visual Basic)을 참조하십시오.

할당 연산자(=, &=, :=, +=, -=, *=, /=, \=, ^=, <<=, >>=) 뒤


Dim fileStream =
  My.Computer.FileSystem.
    OpenTextFileReader(filePath)


자세한 내용은 기능별 연산자 목록(Visual Basic)을 참조하십시오.

식 내에서 이항 연산자(+, -, /, *, Mod, <>, <, >, <=, >=, ^, >>, <<, And, AndAlso, Or, OrElse, Like, Xor) 뒤


Dim memoryInUse =
  My.Computer.Info.TotalPhysicalMemory +
  My.Computer.Info.TotalVirtualMemory -
  My.Computer.Info.AvailablePhysicalMemory -
  My.Computer.Info.AvailableVirtualMemory


자세한 내용은 기능별 연산자 목록(Visual Basic)을 참조하십시오.

Is IsNot 연산자 뒤


If TypeOf inStream Is 
  IO.FileStream AndAlso
  inStream IsNot
  Nothing Then

    ReadFile(inStream)

End If


자세한 내용은 기능별 연산자 목록(Visual Basic)을 참조하십시오.

멤버 한정자 문자(.) 뒤와 멤버 이름 앞. 그러나 With 문을 사용하거나 형식에 대해 초기화 목록의 값을 제공하는 경우에는 멤버 한정자 문자 뒤에 줄 연속 문자(_)를 포함해야 합니다. With 문이나 개체 초기화 목록을 사용하는 경우 할당 연산자(예: =) 뒤에서 줄 바꿈하는 것이 좋습니다.


Dim fileStream =
  My.Computer.FileSystem.
    OpenTextFileReader(filePath)


...


' Not allowed:
' Dim aType = New With { .
'    PropertyName = "Value"

' Allowed:
Dim aType = New With {.PropertyName =
    "Value"}



Dim log As New EventLog()

' Not allowed:
' With log
'    .
'      Source = "Application"
' End With

' Allowed:
With log
    .Source =
      "Application"
End With


자세한 내용은 With...End With 문(Visual Basic) 또는 개체 이니셜라이저: 명명된 형식과 익명 형식(Visual Basic)을 참조하십시오.

XML 축 속성 한정자(., .@ 또는 ...) 뒤. 그러나 With 키워드를 사용하는 경우에는 멤버 한정자를 지정할 때 줄 연속 문자(_)를 포함해야 합니다.


Dim customerName = customerXml.
  <Name>.Value

Dim customerEmail = customerXml...
  <Email>.Value


자세한 내용은 XML 축 속성(Visual Basic)을 참조하십시오.

특성을 지정하는 경우 보다 작음 기호(<) 뒤 또는 보다 큼 기호(>) 앞. 특성을 지정하는 경우 보다 큼 기호(>) 뒤에도 적용됩니다. 그러나 어셈블리 수준 특성이나 모듈 수준 특성을 지정하는 경우에는 줄 연속 문자(_)를 포함해야 합니다.


<
Serializable()
>
Public Class Customer
    Public Property Name As String
    Public Property Company As String
    Public Property Email As String
End Class


자세한 내용은 특성(C# 및 Visual Basic)을 참조하십시오.

쿼리 연산자(Aggregate, Distinct, From, Group By, Group Join, Join, Let, Order By, Select, Skip, Skip While, Take, Take While, Where, In, Into, On, AscendingDescending) 앞과 뒤. 여러 키워드로 구성된 쿼리 연산자(Order By, Group Join, Take WhileSkip While)의 키워드 사이에서는 줄 바꿈할 수 없습니다.


Dim vsProcesses = From proc In
                    Process.GetProcesses
                  Where proc.MainWindowTitle.Contains("Visual Studio")
                  Select proc.ProcessName, proc.Id,
                         proc.MainWindowTitle


자세한 내용은 쿼리(Visual Basic)를 참조하십시오.

For Each 문의 In 키워드 뒤


For Each p In
  vsProcesses

    Console.WriteLine("{0}" & vbTab & "{1}" & vbTab & "{2}",
      p.ProcessName,
      p.Id,
      p.MainWindowTitle)
Next


자세한 내용은 For Each...Next 문(Visual Basic)을 참조하십시오.

컬렉션 이니셜라이저의 From 키워드 뒤


Dim days = New List(Of String) From
  {
   "Mo", "Tu", "We", "Th", "F", "Sa", "Su"
  }


자세한 내용은 컬렉션 이니셜라이저 개요(Visual Basic)를 참조하십시오.

소스 코드가 항상 코드 자체만으로 충분한 설명이 되는 것은 아닙니다. 이는 코드를 작성한 프로그래머에게도 마찬가지입니다. 따라서 코드를 좀 더 상세히 설명하기 위해 대부분의 프로그래머들은 주석을 삽입합니다. 코드 내에 주석을 포함하면 나중에 해당 코드에서 읽기 및 기타 작업을 수행하는 모든 사용자가 프로시저 또는 특정 명령을 이해할 수 있습니다. Visual Basic에서는 컴파일하는 동안 주석이 무시되어 컴파일된 코드에 영향을 주지 않습니다.

주석 줄은 아포스트로피(') 또는 REM으로 시작하며 바로 뒤에 공백이 옵니다. 주석 줄은 문자열 내를 제외하고 코드 내 임의의 위치에 추가할 수 있습니다. 문에 주석을 추가하려면 문 뒤에 아포스트로피나 REM을 삽입한 다음 주석을 삽입합니다. 또한 주석을 별도의 줄에 둘 수도 있습니다. 다음 예제에서는 이러한 예를 보여 줍니다.


' This is a comment on a separate code line.
REM This is another comment on a separate code line.
x += a(i) * b(i) ' Add this amount to total.
MsgBox(statusMessage) REM Inform operator of status.


코드 줄을 입력한 다음 이 줄이 파란색 물결선으로 표시되면(오류 메시지도 나타날 수 있음) 해당 문에 구문 오류가 있는 것입니다. 이 경우 작업 목록을 검토하거나 마우스 포인터로 오류를 가리켜 나타나는 오류 메시지를 읽는 방법으로 문에 어떤 문제가 있는지 찾은 다음 이를 해결해야 합니다. 코드의 모든 구문 오류를 수정하기 전에는 프로그램이 제대로 컴파일되지 않습니다.

용어

정의

할당 연산자(Visual Basic)

= , *=, &= 등의 할당 연산자를 다루는 언어 참조 페이지에 대한 링크를 제공합니다.

Visual Basic의 연산자 및 식

여러 요소를 연산자와 결합하여 새 값을 산출하는 방법을 보여 줍니다.

방법: 코드에서 문 분리 및 결합(Visual Basic)

하나의 문을 여러 줄로 나누는 방법과 한 줄에 여러 문을 배치하는 방법을 보여 줍니다.

방법: Label 문(Visual Basic)

코드 줄에 레이블을 지정하는 방법을 보여 줍니다.

커뮤니티 추가 항목

추가
표시: