SlideShare a Scribd company logo
Error-Handling and Debugging
• errors can be grouped into three categories:
       1. Syntax errors
       2. Run-time errors
       3. Logic errors
• Syntax errors occur when you mistype a command or leave out
  an expected phrase or argument.
• Visual Basic detects these errors as they occur and even
  provides help in correcting them.
• You cannot run a Visual Basic program until all syntax errors
  have been corrected.
• A syntax error (compiler error) is a programming mistake that
  violates the rules of Visual Basic, such as a misspelled
  property or keyword.
Error-Handling and Debugging

• Run-time errors are usually beyond your program's control.
  Examples include:
• when a variable takes on an unexpected value (divide by zero),
  when a drive door is left open, or when a file is not found. Visual
  Basic allows you to trap such errors and make attempts to correct
  them.
• Logic errors are the most difficult to find. With logic errors, the
  program will usually run, but will produce incorrect or unexpected
  results.
• A logic error is a human error — a programming mistake that makes
  the program code produce the wrong results
• The Visual Basic debugger is an aid in detecting logic errors.
•
Error-Handling and Debugging
• Some ways to minimize errors:
• Design your application carefully. More design time
  means less debugging time.
• Use comments where applicable to help you
  remember what you were trying to do.
• Use consistent and meaningful naming conventions
  for your variables, objects,and procedures.
Error-Handling and Debugging
• Run-Time Error Trapping and Handling
• Run-time errors are trappable.
• That is, Visual Basic recognizes an error has occurred
  and enables you to trap it and take corrective action.
• Error trapping is enabled with the On Error statement:
1. On Error GoTo label
2. On Error GoTo 0
3. On Error GoTo line#
4. On Error Resume Next
Error-Handling and Debugging
1. On Error GoTo label
• ddThe Visual Basic On Error GoTo statement is the
  foundation of handling trappable errors.
• When you execute an On Error GoTo Label statement
  in your code, execution is transferred to the code
  starting at Label if a trappable error has occurred.
Error-Handling and Debugging
• The best way to explain how to use error trapping is to look at
  an outline of an example procedure with error trapping.
      Sub SubExample()
      .       . [Declare variables, ...]
• .                   On Error GoTo HandleErrors
• .           . [Procedure code]
• .                          Exit Sub
              HandleErrors:
• .                          [Error handling code]
      End Sub
Error-Handling and Debugging
• Once you have set up the variable declarations, constant
  definitions, and any other procedure preliminaries, the On
  Error statement is executed to enable error trapping.
• Your normal procedure code follows this statement.
• The error handling code goes at the end of the procedure,
  following the HandleErrors statement label.
• This is the code that is executed if an error is encountered
  anywhere in the Sub procedure.
• Note you must exit (with Exit Sub) from the code before
  reaching the HandleErrors line to avoid inadvertent
  execution of the error handling code.
Error-Handling and Debugging
• On Error GoTo 0
• Since the error handling code is in the same procedure
  where an error occurs, all variables in that procedure are
  available for possible corrective action.
• If at some time in your procedure, you want to turn off
  error trapping, that is done with the following
  statement:On Error GoTo 0
• The Err object returns, in its Number property
  (Err.Number), the number associated with the current
  error condition.
• The Error() function takes this error number as its
  argument and returns a string description of the error.
Error-Handling and Debugging
• Once an error has been trapped and some action taken, control must be
  returned to your application.
• That control is returned via the Resume statement. There are three
  options:
• Resume                Lets you retry the operation that caused the
                        error. That is, control is returned to the line
                        where the error occurred. This could be
                        dangerous in that, if the error has not been
                        corrected (via code or by the user), an infinite
                        loop between the error handler and the
                        procedure code may result.
• Resume Next           Program control is returned to the line
                        immediately following the line where the error
                        occurred.
• Resume label        Program control is returned to the line labeled label.
Error-Handling and Debugging
• On Error Resume Next
• The On Error Resume Next statement provides an
  easy way to disregard errors, if you want to do so.
• Once you execute this statement, execution continues
  with the next line of code if the current line generates
  an error, and the error is disregarded.
Error-Handling and Debugging
• Debugging In Visual Basic
• Visual Basic offers a powerful suite of debugging options—
  notably the ability to single-step through your code as it’s
  executing.
• The standard way to debug is to place a breakpoint at a
  particular line in your code, and when execution reaches that
  line, it will halt and Visual Basic will enter the Debug state,
  giving you access to your code and variables.
• You can examine the contents of those variables and work
  through your code line by line, watching program execution
  behind the scenes.
• You place a breakpoint in code by moving the text insertion
  caret to that line and either selecting Toggle Breakpoint in the
  Debug menu or pressing F9.
Error-Handling and Debugging
• To move through your program step-by-step, you can
   select these stepping options in the Debug menu:
• Step Into—Single-step through the code, entering
                     called procedures if encountered.
• Step Over —Single-step through the code, stepping
              over procedure calls.
• Step Out— Step out of the current procedure.
Error-Handling and Debugging
• immediate window
• You can print directly to the immediate window while an
  application is running.
• Sometimes, this is all the debugging you may need. A few
  carefully placed print statements can sometimes clear up
  all logic errors, especially in small applications.
• To print to the immediate window, use the Print method:
• print[List of variables separated by commas or semi-
  colons]
• Eg: ?a;b or print a; b
Error-Handling and Debugging
• Locals Window
• The locals window shows the value of any variables
  within the scope of the current procedure.
• As execution switches from procedure to procedure,
  the contents of this window changes to reflect only
  the variables applicable to the current procedure.
• Repeat the above example and notice the values of A
  and B also appear in the locals window.
Error-Handling and Debugging
• Watch Expressions
• The Add Watch option on the Debug menu allows you to
  establish watch expressions for your application.
• Watch expressions can be variable values or logical
  expressions you want to view or test. Values of watch
  expressions are displayed in the watch window.
• In break mode, you can use the Quick Watch button on the
  toolbar to add watch expressions you need.
• Simply put the cursor on the variable or expression you want
  to add to the watch list and click the Quick Watch button.
• Watch expressions can be edited using the Edit Watch option
  on the Debug menu.
Error-Handling and Debugging
Error-Handling and Debugging
Error-Handling and Debugging
Ad

More Related Content

What's hot (20)

Java exception handling
Java exception handlingJava exception handling
Java exception handling
BHUVIJAYAVELU
 
Coupling and cohesion
Coupling and cohesionCoupling and cohesion
Coupling and cohesion
Sutha31
 
Java Data Types
Java Data TypesJava Data Types
Java Data Types
Spotle.ai
 
Operator precedence
Operator precedenceOperator precedence
Operator precedence
Akshaya Arunan
 
Event Handling in java
Event Handling in javaEvent Handling in java
Event Handling in java
Google
 
Java Exception handling
Java Exception handlingJava Exception handling
Java Exception handling
kamal kotecha
 
Visual basic 6.0
Visual basic 6.0Visual basic 6.0
Visual basic 6.0
Aarti P
 
Lecture 1 introduction to vb.net
Lecture 1   introduction to vb.netLecture 1   introduction to vb.net
Lecture 1 introduction to vb.net
MUKALU STEVEN
 
Type conversion
Type conversionType conversion
Type conversion
Frijo Francis
 
Ch 7 data binding
Ch 7 data bindingCh 7 data binding
Ch 7 data binding
Madhuri Kavade
 
Looping statements in Java
Looping statements in JavaLooping statements in Java
Looping statements in Java
Jin Castor
 
Java basics and java variables
Java basics and java variablesJava basics and java variables
Java basics and java variables
Pushpendra Tyagi
 
Stack data structure
Stack data structureStack data structure
Stack data structure
Tech_MX
 
Peephole optimization techniques in compiler design
Peephole optimization techniques in compiler designPeephole optimization techniques in compiler design
Peephole optimization techniques in compiler design
Anul Chaudhary
 
Introduction to Visual Basic
Introduction to Visual Basic Introduction to Visual Basic
Introduction to Visual Basic
Amity University | FMS - DU | IMT | Stratford University | KKMI International Institute | AIMA | DTU
 
Java awt (abstract window toolkit)
Java awt (abstract window toolkit)Java awt (abstract window toolkit)
Java awt (abstract window toolkit)
Elizabeth alexander
 
Sdi & mdi
Sdi & mdiSdi & mdi
Sdi & mdi
BABAVALI S
 
Unit 4-booth algorithm
Unit 4-booth algorithmUnit 4-booth algorithm
Unit 4-booth algorithm
vishal choudhary
 
Type casting
Type castingType casting
Type casting
simarsimmygrewal
 
Applets in java
Applets in javaApplets in java
Applets in java
Wani Zahoor
 

Similar to Error handling and debugging in vb (20)

Debugging
DebuggingDebugging
Debugging
Ajeng Savitri
 
VISUAL_BASIC_LECTURE_NOTE_A_Z_MADE_EASY.pdf
VISUAL_BASIC_LECTURE_NOTE_A_Z_MADE_EASY.pdfVISUAL_BASIC_LECTURE_NOTE_A_Z_MADE_EASY.pdf
VISUAL_BASIC_LECTURE_NOTE_A_Z_MADE_EASY.pdf
NALANDACSCCENTRE
 
C programming for Computing Techniques
C programming for Computing TechniquesC programming for Computing Techniques
C programming for Computing Techniques
Appili Vamsi Krishna
 
Debugging
DebuggingDebugging
Debugging
nicky_walters
 
classVII_Coding_Teacher_Presentation.pptx
classVII_Coding_Teacher_Presentation.pptxclassVII_Coding_Teacher_Presentation.pptx
classVII_Coding_Teacher_Presentation.pptx
ssusere336f4
 
Java developer trainee implementation and import
Java developer trainee implementation and importJava developer trainee implementation and import
Java developer trainee implementation and import
iamluqman0403
 
Exception handling
Exception handlingException handling
Exception handling
pooja kumari
 
introduction to problem solving and programming
introduction to problem solving and programmingintroduction to problem solving and programming
introduction to problem solving and programming
chaudhariresham6
 
Unit 3.1 Algorithm and Flowchart
Unit 3.1 Algorithm and FlowchartUnit 3.1 Algorithm and Flowchart
Unit 3.1 Algorithm and Flowchart
Bom Khati
 
2.2 Demonstrate the understanding of Programming Life Cycle
2.2 Demonstrate the understanding of Programming Life Cycle2.2 Demonstrate the understanding of Programming Life Cycle
2.2 Demonstrate the understanding of Programming Life Cycle
Frankie Jones
 
Algorithmic problem sloving
Algorithmic problem slovingAlgorithmic problem sloving
Algorithmic problem sloving
Mani Kandan
 
Programming_Lecture_1.pptx
Programming_Lecture_1.pptxProgramming_Lecture_1.pptx
Programming_Lecture_1.pptx
shoaibkhan716300
 
Error Detection & Recovery.pptx
Error Detection & Recovery.pptxError Detection & Recovery.pptx
Error Detection & Recovery.pptx
MohibKhan79
 
Debugging MAD lecture june .pptx
Debugging MAD lecture june .pptxDebugging MAD lecture june .pptx
Debugging MAD lecture june .pptx
ArishaNaz2
 
Lecture 3.1.1 Try Throw Catch.pptx
Lecture 3.1.1 Try Throw Catch.pptxLecture 3.1.1 Try Throw Catch.pptx
Lecture 3.1.1 Try Throw Catch.pptx
sunilsoni446112
 
Error Detection & Recovery
Error Detection & RecoveryError Detection & Recovery
Error Detection & Recovery
Akhil Kaushik
 
F6dc1 session6 c++
F6dc1 session6 c++F6dc1 session6 c++
F6dc1 session6 c++
Mukund Trivedi
 
Algorithm.pdf
Algorithm.pdfAlgorithm.pdf
Algorithm.pdf
MIT,Imphal
 
Java Exceptions and Exception Handling
 Java  Exceptions and Exception Handling Java  Exceptions and Exception Handling
Java Exceptions and Exception Handling
MaqdamYasir
 
Unit-5 Principles of Programming .pptx
Unit-5  Principles of  Programming   .pptxUnit-5  Principles of  Programming   .pptx
Unit-5 Principles of Programming .pptx
hussainshoaib1102
 
VISUAL_BASIC_LECTURE_NOTE_A_Z_MADE_EASY.pdf
VISUAL_BASIC_LECTURE_NOTE_A_Z_MADE_EASY.pdfVISUAL_BASIC_LECTURE_NOTE_A_Z_MADE_EASY.pdf
VISUAL_BASIC_LECTURE_NOTE_A_Z_MADE_EASY.pdf
NALANDACSCCENTRE
 
C programming for Computing Techniques
C programming for Computing TechniquesC programming for Computing Techniques
C programming for Computing Techniques
Appili Vamsi Krishna
 
classVII_Coding_Teacher_Presentation.pptx
classVII_Coding_Teacher_Presentation.pptxclassVII_Coding_Teacher_Presentation.pptx
classVII_Coding_Teacher_Presentation.pptx
ssusere336f4
 
Java developer trainee implementation and import
Java developer trainee implementation and importJava developer trainee implementation and import
Java developer trainee implementation and import
iamluqman0403
 
Exception handling
Exception handlingException handling
Exception handling
pooja kumari
 
introduction to problem solving and programming
introduction to problem solving and programmingintroduction to problem solving and programming
introduction to problem solving and programming
chaudhariresham6
 
Unit 3.1 Algorithm and Flowchart
Unit 3.1 Algorithm and FlowchartUnit 3.1 Algorithm and Flowchart
Unit 3.1 Algorithm and Flowchart
Bom Khati
 
2.2 Demonstrate the understanding of Programming Life Cycle
2.2 Demonstrate the understanding of Programming Life Cycle2.2 Demonstrate the understanding of Programming Life Cycle
2.2 Demonstrate the understanding of Programming Life Cycle
Frankie Jones
 
Algorithmic problem sloving
Algorithmic problem slovingAlgorithmic problem sloving
Algorithmic problem sloving
Mani Kandan
 
Programming_Lecture_1.pptx
Programming_Lecture_1.pptxProgramming_Lecture_1.pptx
Programming_Lecture_1.pptx
shoaibkhan716300
 
Error Detection & Recovery.pptx
Error Detection & Recovery.pptxError Detection & Recovery.pptx
Error Detection & Recovery.pptx
MohibKhan79
 
Debugging MAD lecture june .pptx
Debugging MAD lecture june .pptxDebugging MAD lecture june .pptx
Debugging MAD lecture june .pptx
ArishaNaz2
 
Lecture 3.1.1 Try Throw Catch.pptx
Lecture 3.1.1 Try Throw Catch.pptxLecture 3.1.1 Try Throw Catch.pptx
Lecture 3.1.1 Try Throw Catch.pptx
sunilsoni446112
 
Error Detection & Recovery
Error Detection & RecoveryError Detection & Recovery
Error Detection & Recovery
Akhil Kaushik
 
Java Exceptions and Exception Handling
 Java  Exceptions and Exception Handling Java  Exceptions and Exception Handling
Java Exceptions and Exception Handling
MaqdamYasir
 
Unit-5 Principles of Programming .pptx
Unit-5  Principles of  Programming   .pptxUnit-5  Principles of  Programming   .pptx
Unit-5 Principles of Programming .pptx
hussainshoaib1102
 
Ad

Recently uploaded (20)

Ranking_Felicidade_2024_com_Educacao_Marketing Educacional_V2.pdf
Ranking_Felicidade_2024_com_Educacao_Marketing Educacional_V2.pdfRanking_Felicidade_2024_com_Educacao_Marketing Educacional_V2.pdf
Ranking_Felicidade_2024_com_Educacao_Marketing Educacional_V2.pdf
Rafael Villas B
 
How to Create A Todo List In Todo of Odoo 18
How to Create A Todo List In Todo of Odoo 18How to Create A Todo List In Todo of Odoo 18
How to Create A Todo List In Todo of Odoo 18
Celine George
 
THE STG QUIZ GROUP D.pptx quiz by Ridip Hazarika
THE STG QUIZ GROUP D.pptx   quiz by Ridip HazarikaTHE STG QUIZ GROUP D.pptx   quiz by Ridip Hazarika
THE STG QUIZ GROUP D.pptx quiz by Ridip Hazarika
Ridip Hazarika
 
Stein, Hunt, Green letter to Congress April 2025
Stein, Hunt, Green letter to Congress April 2025Stein, Hunt, Green letter to Congress April 2025
Stein, Hunt, Green letter to Congress April 2025
Mebane Rash
 
PHYSIOLOGY MCQS By DR. NASIR MUSTAFA (PHYSIOLOGY)
PHYSIOLOGY MCQS By DR. NASIR MUSTAFA (PHYSIOLOGY)PHYSIOLOGY MCQS By DR. NASIR MUSTAFA (PHYSIOLOGY)
PHYSIOLOGY MCQS By DR. NASIR MUSTAFA (PHYSIOLOGY)
Dr. Nasir Mustafa
 
Debunking the Myths behind AI - v1, Carl Dalby
Debunking the Myths behind AI -  v1, Carl DalbyDebunking the Myths behind AI -  v1, Carl Dalby
Debunking the Myths behind AI - v1, Carl Dalby
Association for Project Management
 
APGAR SCORE BY sweety Tamanna Mahapatra MSc Pediatric
APGAR SCORE  BY sweety Tamanna Mahapatra MSc PediatricAPGAR SCORE  BY sweety Tamanna Mahapatra MSc Pediatric
APGAR SCORE BY sweety Tamanna Mahapatra MSc Pediatric
SweetytamannaMohapat
 
Sugar-Sensing Mechanism in plants....pptx
Sugar-Sensing Mechanism in plants....pptxSugar-Sensing Mechanism in plants....pptx
Sugar-Sensing Mechanism in plants....pptx
Dr. Renu Jangid
 
World war-1(Causes & impacts at a glance) PPT by Simanchala Sarab(BABed,sem-4...
World war-1(Causes & impacts at a glance) PPT by Simanchala Sarab(BABed,sem-4...World war-1(Causes & impacts at a glance) PPT by Simanchala Sarab(BABed,sem-4...
World war-1(Causes & impacts at a glance) PPT by Simanchala Sarab(BABed,sem-4...
larencebapu132
 
Biophysics Chapter 3 Methods of Studying Macromolecules.pdf
Biophysics Chapter 3 Methods of Studying Macromolecules.pdfBiophysics Chapter 3 Methods of Studying Macromolecules.pdf
Biophysics Chapter 3 Methods of Studying Macromolecules.pdf
PKLI-Institute of Nursing and Allied Health Sciences Lahore , Pakistan.
 
Link your Lead Opportunities into Spreadsheet using odoo CRM
Link your Lead Opportunities into Spreadsheet using odoo CRMLink your Lead Opportunities into Spreadsheet using odoo CRM
Link your Lead Opportunities into Spreadsheet using odoo CRM
Celine George
 
Introduction to Vibe Coding and Vibe Engineering
Introduction to Vibe Coding and Vibe EngineeringIntroduction to Vibe Coding and Vibe Engineering
Introduction to Vibe Coding and Vibe Engineering
Damian T. Gordon
 
Presentation on Tourism Product Development By Md Shaifullar Rabbi
Presentation on Tourism Product Development By Md Shaifullar RabbiPresentation on Tourism Product Development By Md Shaifullar Rabbi
Presentation on Tourism Product Development By Md Shaifullar Rabbi
Md Shaifullar Rabbi
 
SCI BIZ TECH QUIZ (OPEN) PRELIMS XTASY 2025.pptx
SCI BIZ TECH QUIZ (OPEN) PRELIMS XTASY 2025.pptxSCI BIZ TECH QUIZ (OPEN) PRELIMS XTASY 2025.pptx
SCI BIZ TECH QUIZ (OPEN) PRELIMS XTASY 2025.pptx
Ronisha Das
 
GDGLSPGCOER - Git and GitHub Workshop.pptx
GDGLSPGCOER - Git and GitHub Workshop.pptxGDGLSPGCOER - Git and GitHub Workshop.pptx
GDGLSPGCOER - Git and GitHub Workshop.pptx
azeenhodekar
 
dynastic art of the Pallava dynasty south India
dynastic art of the Pallava dynasty south Indiadynastic art of the Pallava dynasty south India
dynastic art of the Pallava dynasty south India
PrachiSontakke5
 
How to manage Multiple Warehouses for multiple floors in odoo point of sale
How to manage Multiple Warehouses for multiple floors in odoo point of saleHow to manage Multiple Warehouses for multiple floors in odoo point of sale
How to manage Multiple Warehouses for multiple floors in odoo point of sale
Celine George
 
Grade 2 - Mathematics - Printable Worksheet
Grade 2 - Mathematics - Printable WorksheetGrade 2 - Mathematics - Printable Worksheet
Grade 2 - Mathematics - Printable Worksheet
Sritoma Majumder
 
03#UNTAGGED. Generosity in architecture.
03#UNTAGGED. Generosity in architecture.03#UNTAGGED. Generosity in architecture.
03#UNTAGGED. Generosity in architecture.
MCH
 
Kenan Fellows Participants, Projects 2025-26 Cohort
Kenan Fellows Participants, Projects 2025-26 CohortKenan Fellows Participants, Projects 2025-26 Cohort
Kenan Fellows Participants, Projects 2025-26 Cohort
EducationNC
 
Ranking_Felicidade_2024_com_Educacao_Marketing Educacional_V2.pdf
Ranking_Felicidade_2024_com_Educacao_Marketing Educacional_V2.pdfRanking_Felicidade_2024_com_Educacao_Marketing Educacional_V2.pdf
Ranking_Felicidade_2024_com_Educacao_Marketing Educacional_V2.pdf
Rafael Villas B
 
How to Create A Todo List In Todo of Odoo 18
How to Create A Todo List In Todo of Odoo 18How to Create A Todo List In Todo of Odoo 18
How to Create A Todo List In Todo of Odoo 18
Celine George
 
THE STG QUIZ GROUP D.pptx quiz by Ridip Hazarika
THE STG QUIZ GROUP D.pptx   quiz by Ridip HazarikaTHE STG QUIZ GROUP D.pptx   quiz by Ridip Hazarika
THE STG QUIZ GROUP D.pptx quiz by Ridip Hazarika
Ridip Hazarika
 
Stein, Hunt, Green letter to Congress April 2025
Stein, Hunt, Green letter to Congress April 2025Stein, Hunt, Green letter to Congress April 2025
Stein, Hunt, Green letter to Congress April 2025
Mebane Rash
 
PHYSIOLOGY MCQS By DR. NASIR MUSTAFA (PHYSIOLOGY)
PHYSIOLOGY MCQS By DR. NASIR MUSTAFA (PHYSIOLOGY)PHYSIOLOGY MCQS By DR. NASIR MUSTAFA (PHYSIOLOGY)
PHYSIOLOGY MCQS By DR. NASIR MUSTAFA (PHYSIOLOGY)
Dr. Nasir Mustafa
 
APGAR SCORE BY sweety Tamanna Mahapatra MSc Pediatric
APGAR SCORE  BY sweety Tamanna Mahapatra MSc PediatricAPGAR SCORE  BY sweety Tamanna Mahapatra MSc Pediatric
APGAR SCORE BY sweety Tamanna Mahapatra MSc Pediatric
SweetytamannaMohapat
 
Sugar-Sensing Mechanism in plants....pptx
Sugar-Sensing Mechanism in plants....pptxSugar-Sensing Mechanism in plants....pptx
Sugar-Sensing Mechanism in plants....pptx
Dr. Renu Jangid
 
World war-1(Causes & impacts at a glance) PPT by Simanchala Sarab(BABed,sem-4...
World war-1(Causes & impacts at a glance) PPT by Simanchala Sarab(BABed,sem-4...World war-1(Causes & impacts at a glance) PPT by Simanchala Sarab(BABed,sem-4...
World war-1(Causes & impacts at a glance) PPT by Simanchala Sarab(BABed,sem-4...
larencebapu132
 
Link your Lead Opportunities into Spreadsheet using odoo CRM
Link your Lead Opportunities into Spreadsheet using odoo CRMLink your Lead Opportunities into Spreadsheet using odoo CRM
Link your Lead Opportunities into Spreadsheet using odoo CRM
Celine George
 
Introduction to Vibe Coding and Vibe Engineering
Introduction to Vibe Coding and Vibe EngineeringIntroduction to Vibe Coding and Vibe Engineering
Introduction to Vibe Coding and Vibe Engineering
Damian T. Gordon
 
Presentation on Tourism Product Development By Md Shaifullar Rabbi
Presentation on Tourism Product Development By Md Shaifullar RabbiPresentation on Tourism Product Development By Md Shaifullar Rabbi
Presentation on Tourism Product Development By Md Shaifullar Rabbi
Md Shaifullar Rabbi
 
SCI BIZ TECH QUIZ (OPEN) PRELIMS XTASY 2025.pptx
SCI BIZ TECH QUIZ (OPEN) PRELIMS XTASY 2025.pptxSCI BIZ TECH QUIZ (OPEN) PRELIMS XTASY 2025.pptx
SCI BIZ TECH QUIZ (OPEN) PRELIMS XTASY 2025.pptx
Ronisha Das
 
GDGLSPGCOER - Git and GitHub Workshop.pptx
GDGLSPGCOER - Git and GitHub Workshop.pptxGDGLSPGCOER - Git and GitHub Workshop.pptx
GDGLSPGCOER - Git and GitHub Workshop.pptx
azeenhodekar
 
dynastic art of the Pallava dynasty south India
dynastic art of the Pallava dynasty south Indiadynastic art of the Pallava dynasty south India
dynastic art of the Pallava dynasty south India
PrachiSontakke5
 
How to manage Multiple Warehouses for multiple floors in odoo point of sale
How to manage Multiple Warehouses for multiple floors in odoo point of saleHow to manage Multiple Warehouses for multiple floors in odoo point of sale
How to manage Multiple Warehouses for multiple floors in odoo point of sale
Celine George
 
Grade 2 - Mathematics - Printable Worksheet
Grade 2 - Mathematics - Printable WorksheetGrade 2 - Mathematics - Printable Worksheet
Grade 2 - Mathematics - Printable Worksheet
Sritoma Majumder
 
03#UNTAGGED. Generosity in architecture.
03#UNTAGGED. Generosity in architecture.03#UNTAGGED. Generosity in architecture.
03#UNTAGGED. Generosity in architecture.
MCH
 
Kenan Fellows Participants, Projects 2025-26 Cohort
Kenan Fellows Participants, Projects 2025-26 CohortKenan Fellows Participants, Projects 2025-26 Cohort
Kenan Fellows Participants, Projects 2025-26 Cohort
EducationNC
 
Ad

Error handling and debugging in vb

  • 1. Error-Handling and Debugging • errors can be grouped into three categories: 1. Syntax errors 2. Run-time errors 3. Logic errors • Syntax errors occur when you mistype a command or leave out an expected phrase or argument. • Visual Basic detects these errors as they occur and even provides help in correcting them. • You cannot run a Visual Basic program until all syntax errors have been corrected. • A syntax error (compiler error) is a programming mistake that violates the rules of Visual Basic, such as a misspelled property or keyword.
  • 2. Error-Handling and Debugging • Run-time errors are usually beyond your program's control. Examples include: • when a variable takes on an unexpected value (divide by zero), when a drive door is left open, or when a file is not found. Visual Basic allows you to trap such errors and make attempts to correct them. • Logic errors are the most difficult to find. With logic errors, the program will usually run, but will produce incorrect or unexpected results. • A logic error is a human error — a programming mistake that makes the program code produce the wrong results • The Visual Basic debugger is an aid in detecting logic errors. •
  • 3. Error-Handling and Debugging • Some ways to minimize errors: • Design your application carefully. More design time means less debugging time. • Use comments where applicable to help you remember what you were trying to do. • Use consistent and meaningful naming conventions for your variables, objects,and procedures.
  • 4. Error-Handling and Debugging • Run-Time Error Trapping and Handling • Run-time errors are trappable. • That is, Visual Basic recognizes an error has occurred and enables you to trap it and take corrective action. • Error trapping is enabled with the On Error statement: 1. On Error GoTo label 2. On Error GoTo 0 3. On Error GoTo line# 4. On Error Resume Next
  • 5. Error-Handling and Debugging 1. On Error GoTo label • ddThe Visual Basic On Error GoTo statement is the foundation of handling trappable errors. • When you execute an On Error GoTo Label statement in your code, execution is transferred to the code starting at Label if a trappable error has occurred.
  • 6. Error-Handling and Debugging • The best way to explain how to use error trapping is to look at an outline of an example procedure with error trapping. Sub SubExample() . . [Declare variables, ...] • . On Error GoTo HandleErrors • . . [Procedure code] • . Exit Sub HandleErrors: • . [Error handling code] End Sub
  • 7. Error-Handling and Debugging • Once you have set up the variable declarations, constant definitions, and any other procedure preliminaries, the On Error statement is executed to enable error trapping. • Your normal procedure code follows this statement. • The error handling code goes at the end of the procedure, following the HandleErrors statement label. • This is the code that is executed if an error is encountered anywhere in the Sub procedure. • Note you must exit (with Exit Sub) from the code before reaching the HandleErrors line to avoid inadvertent execution of the error handling code.
  • 8. Error-Handling and Debugging • On Error GoTo 0 • Since the error handling code is in the same procedure where an error occurs, all variables in that procedure are available for possible corrective action. • If at some time in your procedure, you want to turn off error trapping, that is done with the following statement:On Error GoTo 0 • The Err object returns, in its Number property (Err.Number), the number associated with the current error condition. • The Error() function takes this error number as its argument and returns a string description of the error.
  • 9. Error-Handling and Debugging • Once an error has been trapped and some action taken, control must be returned to your application. • That control is returned via the Resume statement. There are three options: • Resume Lets you retry the operation that caused the error. That is, control is returned to the line where the error occurred. This could be dangerous in that, if the error has not been corrected (via code or by the user), an infinite loop between the error handler and the procedure code may result. • Resume Next Program control is returned to the line immediately following the line where the error occurred. • Resume label Program control is returned to the line labeled label.
  • 10. Error-Handling and Debugging • On Error Resume Next • The On Error Resume Next statement provides an easy way to disregard errors, if you want to do so. • Once you execute this statement, execution continues with the next line of code if the current line generates an error, and the error is disregarded.
  • 11. Error-Handling and Debugging • Debugging In Visual Basic • Visual Basic offers a powerful suite of debugging options— notably the ability to single-step through your code as it’s executing. • The standard way to debug is to place a breakpoint at a particular line in your code, and when execution reaches that line, it will halt and Visual Basic will enter the Debug state, giving you access to your code and variables. • You can examine the contents of those variables and work through your code line by line, watching program execution behind the scenes. • You place a breakpoint in code by moving the text insertion caret to that line and either selecting Toggle Breakpoint in the Debug menu or pressing F9.
  • 12. Error-Handling and Debugging • To move through your program step-by-step, you can select these stepping options in the Debug menu: • Step Into—Single-step through the code, entering called procedures if encountered. • Step Over —Single-step through the code, stepping over procedure calls. • Step Out— Step out of the current procedure.
  • 13. Error-Handling and Debugging • immediate window • You can print directly to the immediate window while an application is running. • Sometimes, this is all the debugging you may need. A few carefully placed print statements can sometimes clear up all logic errors, especially in small applications. • To print to the immediate window, use the Print method: • print[List of variables separated by commas or semi- colons] • Eg: ?a;b or print a; b
  • 14. Error-Handling and Debugging • Locals Window • The locals window shows the value of any variables within the scope of the current procedure. • As execution switches from procedure to procedure, the contents of this window changes to reflect only the variables applicable to the current procedure. • Repeat the above example and notice the values of A and B also appear in the locals window.
  • 15. Error-Handling and Debugging • Watch Expressions • The Add Watch option on the Debug menu allows you to establish watch expressions for your application. • Watch expressions can be variable values or logical expressions you want to view or test. Values of watch expressions are displayed in the watch window. • In break mode, you can use the Quick Watch button on the toolbar to add watch expressions you need. • Simply put the cursor on the variable or expression you want to add to the watch list and click the Quick Watch button. • Watch expressions can be edited using the Edit Watch option on the Debug menu.