Difference between revisions of "NL/Documentation/BASIC Guide/Error Handling"
(→Query's met betrekking tot informatie over fouten) |
(→Tips for Structured Error Handling) |
||
Line 83: | Line 83: | ||
In {{OOo}} Basic wordt dit gedaan met de opdrachten <tt>On Error</tt> of <tt>Resume</tt>. }} | In {{OOo}} Basic wordt dit gedaan met de opdrachten <tt>On Error</tt> of <tt>Resume</tt>. }} | ||
− | == Tips | + | == Tips voor gestructureerde foutafhandeling == |
− | + | Zowel de definitie-opdracht <tt>On Error</tt>, als de terugkeer-opdracht <tt>Resume</tt> zijn varianten van de construct <tt>Goto</tt>. | |
− | + | Als u uw code netjes wilt structureren om te voorkomen dat fouten worden gegenereerd bij het gebruik van deze construct, zou u geen opdrachten voor springen moeten gebruiken, zonder die in de gaten te houden. | |
− | + | Voorzichtigheid is geboden bij het gebruik van de opdracht <tt>On Error Resume Next</tt>, omdat dit alle openstaande foutmeldingen opheft. | |
− | + | De beste oplossing is om maar één benadering te gebruiken voor foutafhandeling binnen een programma – houdt foutafhandeling gescheiden van de actuele programmacode en spring niet terug naar de oorspronkelijke code nadat de fout optrad. | |
− | + | Het volgende is een voorbeeld van een procedure voor foutafhandeling: | |
<source lang="oobas"> | <source lang="oobas"> | ||
Sub Example | Sub Example | ||
− | ' | + | ' Definieer foutafhandeling aan het begin van de functie |
On Error Goto ErrorHandler | On Error Goto ErrorHandler | ||
− | ' ... | + | ' ... Hier staat de actuele code voor het programma |
− | On Error Goto 0 ' | + | On Error Goto 0 ' Deactiveert de foutafhandeling |
− | ' | + | ' Einde van reguliere implementatie van het programma |
Exit Sub | Exit Sub | ||
− | ' | + | ' Beginpunt van de foutafhandeling |
ErrorHandler: | ErrorHandler: | ||
− | ' | + | ' Controleer welke fout werd verwacht |
If Err = ExpectedErrorNo Then | If Err = ExpectedErrorNo Then | ||
− | ' ... | + | ' ... Verwerk de fout |
Else | Else | ||
− | ' ... | + | ' ... Waarschuwing voor een onverwachte fout |
End If | End If | ||
− | On Error Goto 0 ' | + | On Error Goto 0 ' Deactiveert de foutafhandeling |
End Sub | End Sub | ||
</source> | </source> | ||
− | + | Deze procedure begint met de definitie van een foutafhandeling, gevolgd door de eigenlijke programmacode. Aan het einde van de programmacode wordt de foutafhandeling gedeactiveerd door de aanroep <tt>On Error Goto 0</tt> en de implementatie van deprocedure wordt beëindigd door de opdracht <tt>Exit Sub</tt> (niet te verwarren met <tt>End Sub</tt>). | |
− | + | Het voorbeeld controleert eerst of het foutnummer overeenkomt met het verwachte nummer (zoals opgeslagen in de denkbeeldige constante <tt>ExpectedErrorNo</tt>) en behandelt de fout dienovereenkomstig. Als een andere fout optreedt, geeft het systeem een waarschuwing weer. Het is belangrijk om het foutnummer te controleren, zodat onverwachte fouten kunnen worden herkend. | |
− | + | ||
− | + | ||
+ | De aanroep <tt>On Error Goto 0</tt> aan het einde van de code herstelt de statusinformatie van de fout (de foutcode in de systeemvariabelen <tt>Err</tt>) zodat een fout die op een later tijdstip voorkomt toch duidelijk herkend kan worden. | ||
{{InterWiki Languages BasicGuide|articletitle=Documentation/BASIC Guide/Error Handling}} | {{InterWiki Languages BasicGuide|articletitle=Documentation/BASIC Guide/Error Handling}} | ||
{{PDL1}} | {{PDL1}} |
Revision as of 12:38, 26 January 2013
Correcte afhandeling van foutsituaties is een van de meest tijdrovende taken van programmeren. Apache OpenOffice BASIC verschaft een aantal gereedschappen om de foutafhandeling te vereenvoudigen.
De instructie On Error
De instructie On Error is de sleutel voor elke foutafhandeling:
Sub Test On Error Goto ErrorHandler ' ... voer een taak uit gedurende welke een fout zou kunnen optreden Exit Sub ErrorHandler: ' ... individuele code voor foutafhandeling End Sub
De regel On Error Goto ErrorHandler definieert hoe Apache OpenOffice BASIC doorgaat in het geval van een fout. De opdracht Goto ErrorHandler verzekert u er van dat Apache OpenOffice BASIC de huidige programmaregel verlaat en vervolgens de code ErrorHandler: uitvoert.
De opdracht Resume
De opdracht Resume Next vervolgt het programma vanaf de regel die volgt op die waarin de fout voorkwam in het programma nadat de code in de foutafhandeling is uitgevoerd:
ErrorHandler: ' ... individuele code voor foutafhandeling Resume Next
Gebruik de opdracht Resume Proceed om een springpunt te specificeren om het programma door te laten gaan na de foutafhandeling:
ErrorHandler: ' ... individuele code voor foutafhandeling Resume Proceed Proceed: ' ... het programma gaat hier door na de fout
De term Proceed is een label. Het zou bijvoorbeeld A247 kunnen zijn. De syntaxis voor namen van labels is hetzelfde als voor namen van variabelen.
Gebruik de volgende indeling om met een programma door te gaan zonder een foutbericht als er een fout optreedt:
Sub Test On Error Resume Next ' ... voer een taak uit gedurende welke een fout zou kunnen optreden End Sub
Gebruik de opdracht On Error Resume Next voorzichtig want het effect ervan is global.
Query's met betrekking tot informatie over fouten
In foutafhandeling is het handig om een beschrijving van de fout te hebben en te weten waar en waarom die fout optrad:
- De variabele Err bevat een getal dat het type fout identificeert dat optrad.
- De variabele Error$ bevat een beschrijving van de fout.
- De variabele Erl bevat het regelnummer waar de fout optrad.
De aanroep
MsgBox "Fout " & Err & ": " & Error$ & " (regel : " & Erl & ")"
geeft weer hoe de informatie over de fout kan worden weergegeven in een berichtenvenster.
VBA : Waar VBA de foutberichten samenvat in een global object genaamd Err, verschaft Apache OpenOffice Basic de variabelen Err, Error$ en Erl. |
De statusinformatie blijft geldig totdat het programma een opdracht Resume of On Error tegenkomt, waarop de informatie opnieuw wordt ingesteld.
Tips voor gestructureerde foutafhandeling
Zowel de definitie-opdracht On Error, als de terugkeer-opdracht Resume zijn varianten van de construct Goto.
Als u uw code netjes wilt structureren om te voorkomen dat fouten worden gegenereerd bij het gebruik van deze construct, zou u geen opdrachten voor springen moeten gebruiken, zonder die in de gaten te houden.
Voorzichtigheid is geboden bij het gebruik van de opdracht On Error Resume Next, omdat dit alle openstaande foutmeldingen opheft.
De beste oplossing is om maar één benadering te gebruiken voor foutafhandeling binnen een programma – houdt foutafhandeling gescheiden van de actuele programmacode en spring niet terug naar de oorspronkelijke code nadat de fout optrad.
Het volgende is een voorbeeld van een procedure voor foutafhandeling:
Sub Example ' Definieer foutafhandeling aan het begin van de functie On Error Goto ErrorHandler ' ... Hier staat de actuele code voor het programma On Error Goto 0 ' Deactiveert de foutafhandeling ' Einde van reguliere implementatie van het programma Exit Sub ' Beginpunt van de foutafhandeling ErrorHandler: ' Controleer welke fout werd verwacht If Err = ExpectedErrorNo Then ' ... Verwerk de fout Else ' ... Waarschuwing voor een onverwachte fout End If On Error Goto 0 ' Deactiveert de foutafhandeling End Sub
Deze procedure begint met de definitie van een foutafhandeling, gevolgd door de eigenlijke programmacode. Aan het einde van de programmacode wordt de foutafhandeling gedeactiveerd door de aanroep On Error Goto 0 en de implementatie van deprocedure wordt beëindigd door de opdracht Exit Sub (niet te verwarren met End Sub).
Het voorbeeld controleert eerst of het foutnummer overeenkomt met het verwachte nummer (zoals opgeslagen in de denkbeeldige constante ExpectedErrorNo) en behandelt de fout dienovereenkomstig. Als een andere fout optreedt, geeft het systeem een waarschuwing weer. Het is belangrijk om het foutnummer te controleren, zodat onverwachte fouten kunnen worden herkend.
De aanroep On Error Goto 0 aan het einde van de code herstelt de statusinformatie van de fout (de foutcode in de systeemvariabelen Err) zodat een fout die op een later tijdstip voorkomt toch duidelijk herkend kan worden.
Content on this page is licensed under the Public Documentation License (PDL). |