Exit Do
This statement provides a way to exit the loop early.
It can only be used inside a Do - While, Do - Until or a Do - Loop.
This transfers control to the statement that immediately follows the Loop statement.
Exit Do
Do - While
This loops will exit at the start of the third loop.
Public Sub ExitDo1()
Dim icount As Integer
icount = 1
Do While (icount < 5)
If (icount = 3) Then
Exit Do
End If
icount = icount + 1
Loop
End Sub
Do - Until
This loop will exit at the end of the second loop.
Notice that the variable icount is incremented at the start of the loop.
Public Sub ExitDo2()
Dim icount As Integer
icount = 1
Do Until (icount = 5)
icount = icount + 1
If (icount = 3) Then
Exit Do
End If
Loop
End Sub
Do - Loop
This loops through four times.
Public Sub ExitDo3()
Dim icount As Integer
icount = 1
Do
If (icount = 5) Then
Exit Do
End If
icount = icount + 1
Loop
End Sub
Nested Loops
This statement transfers control to the statement that immediately follows the Loop statement.
If a loop is nested, the control is passed only one level up.
Public Sub ExitDo4()
Dim iouter As Integer
Dim inner As Integer
iouter = 1
Do While (iouter < 5)
inner = 1 'reset variable
Do While (inner < 5)
If (inner = 3) Then
Exit Do 'only exits the inner do
End If
inner = inner + 1
Loop
iouter = iouter + 1
Loop
End Sub
Important
You can use one or more Exit Do statements inside the same loop.
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopPrevNext