GoSub...Return Statement

Calls a subroutine that is indicated by a label inside a Sub or a Function. The statements following the label are executed until the next Return statement. Afterwards, the program continues with the statement that follows the GoSub statement.

Синтаксис:


GoSub label[:]

Параметры:

label: A line identifier indicating where to continue execution. The scope of a label in that of the routine it belongs to.

The GoSub statement calls a local subroutine indicated by a label from within a subroutine or a function. The name of the label must end with a colon (":").


  Sub/Function foo
      ' statements
      GoSub label
      ' statements
      Exit Sub/Function
  label:
      ' statements
      Return
  End Sub/Function
Значок предупреждения

Если программа встречает инструкцию Return, которой не предшествует инструкция GoSub, LibreOffice Basic возвращает сообщение об ошибке. Используйте инструкцию Exit Sub или Exit Function, чтобы гарантировать, что программа выйдет из процедуры или функции, прежде чем достигнет следующей инструкции Return.


В следующем примере демонстрируется использование инструкций GoSub и Return. Выполняя участок программы дважды, программа вычисляет квадратный корень двух чисел, введённых пользователем.

Пример:


Sub ExampleGoSub
Dim iInputa As Single
Dim iInputb As Single
Dim iInputc As Single
    iInputa = Int(InputBox("Введите первое число: ","Ввод числа"))
    iInputb = Int(InputBox("Введите второе число: ","Ввод числа"))
    iInputc=iInputa
    GoSub SquareRoot
    Print "Квадратный корень из";iInputa;" равен";iInputc
    iInputc=iInputb
    GoSub SquareRoot
    Print "Квадратный корень из";iInputb;" равен";iInputc
    Exit Sub
SquareRoot:
    iInputc=sqr(iInputc)
    Return
End Sub

Пожалуйста, поддержите нас!