1 / 16

Chapter 6

Chapter 6. Procedures and Functions. Introduction. A procedure is a collection of statements that performs a task Event handlers are a type of procedure A function is a collection of statements that performs a task and returns a value to the part of the program that executed it

obelia
Download Presentation

Chapter 6

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Chapter 6 Procedures and Functions

  2. Introduction • A procedure is a collection of statements that performs a task • Event handlers are a type of procedure • A function is a collection of statements that performs a task and returns a value to the part of the program that executed it • You have already worked with Visual Basic’s built-in functions, such as CInt and IsNumeric • A method can be either a procedure or a function

  3. Section 6.1 Procedures You can write your own general purpose procedures that perform specific tasks. General purpose procedures are not triggered by events, but are called from statements in other procedures.

  4. Procedure Uses • An event handler is a type of procedure • Automatically executed when an event such as a mouse click occurs • General purpose procedures are triggered by statements in other procedures, not by events • Procedures help simplify & modularize code by: • Breaking it into small, manageable pieces • Performing a task that is needed repeatedly • Dividing a program into a set of logical tasks

  5. Declaring a Procedure • The general format of a procedure declaration is as follows: • Sub and End are keywords, both are required • ProcedureName used to refer to procedure, also required • Use Pascal casing to capitalize 1st character of the name and each new word in the name • ParameterList is a list of variables or values being passed to the sub procedure, this is an optional part of your declaration Sub ProcedureName ([ParameterList]) [Statements] End Sub

  6. Scope of Variables • Variables needed only in a procedure, should be declared within that procedure • Creates a local variable with scope only within the procedure where declared • Local variable values are not saved from one procedure call to the next

  7. Section 6.2 Passing Arguments to Procedures When calling a procedure, you can pass it values known as arguments.

  8. Arguments • An Argument is a value passed to a procedure • For example: • Calls the CInt function • Passes txtInput.Text as an argument • Two ways to pass arguments • by value is a temporary copy of the original argument • by reference is the original argument and can be changed CInt(txtInput.Text)

  9. Passing Arguments By Value • intNumber declared as an integer argument • Storage location intNumber created by procedure • A value, 5 in this case, must be supplied and is copied into the storage location for intNumber • The DisplayValue procedure then executes DisplayValue(5) ' Call DisplayValue procedure Sub DisplayValue(ByValintNumber As Integer) ' Display message with number. MessageBox.Show("The number is" & _ CStr(intNumber) & "!") End Sub

  10. Passing Multiple Arguments • Multiple arguments separated by commas • Value of first argument is copied to first • Second to second, etc. ShowSum(intValue1, intValue2) ' Call ShowSum procedure Sub ShowSum(ByVal intNum1 As Integer, ByVal intNum2 As Integer) 'Calculates and displays sum of two integers Dim intSum As Integer intSum = intNum1 + intNum2 MessageBox.Show("The sum is " & CStr(intSum)) End Sub

  11. More about Passing Arguments by Reference • Arguments are usually passed ByVal • New storage location created for procedure • Storage location gets a copy of the value • Changes in value are made to the copy NOT the original value/variable • Calling procedure won’t “see” the changes • Arguments can also be passed ByRef • Procedure points to (references) argument’s original storage location • Changes are made to the original value/variable • Calling procedure “sees” the changes • Tutorial 6-4 demonstrates the difference between ByVal and ByRef

  12. Section 6.3 Functions A function returns a value to the part of the program that called the function.

  13. Declaring a Function • New keyword Function, this is required • Also new is As DataType which states the data type of the value to be returned (required) • Return value is specified in a Return expression, also required Function FunctionName ([ParameterList]) As DataType [Statements] End Function

  14. Function Call Example • The Sum function • Passes the variables decValue1 and decValue2 as arguments • Data types must agree with parameter list • Assigns the value returned by the Sum function to the variable decTotal, which agrees with return value (decimal) decTotal = Sum(decValue1, decValue2) Function Sum(ByVal decNum1 As Decimal, ByVal decNum2 As Decimal) As Decimal Return decNum1 + decNum2 End Function

  15. Returning Nonnumeric Values • Functions can return nonnumeric values, such as strings and Boolean values strCustomer = GetFullName("John", "Martin") Function GetFullName(ByValstrFirst As String, ByValstrLast As String) As String Dim strName As String strName = strFirst & " " & strLast Return strName End Function

  16. Returning Nonnumeric Values • Functions can return nonnumeric values, such as strings and Boolean values, also – more than 1 return line can exist. ONLY ONE RETURN CAN BE USED – after a return statement is encountered during execution, the code leaves the function If IsValid(intValue) = True Then ... Function IsValid(intNum As Integer) As Boolean If intNum >= 0 And intNum <= 100 Then Return True Else Return False End If End Function

More Related