Home arrow Delphi-Kylix arrow Page 2 - Using Try and Finally to Help Prevent Memory Leaks During Dynamic Object Creation in Delphi
DELPHI-KYLIX

Using Try and Finally to Help Prevent Memory Leaks During Dynamic Object Creation in Delphi


Using components in Delphi is child's play as long as your logic is sound. All you need to do is drop components on the form and Delphi takes care of dirtier things like allocating and de-allocating memory for the object. There are times when it doesn't handle memory allocation, however, depending on your needs. This article will explain how to handle those times.

Author Info:
By: Danish Ahmed
Rating: 5 stars5 stars5 stars5 stars5 stars / 5
May 21, 2007
TABLE OF CONTENTS:
  1. · Using Try and Finally to Help Prevent Memory Leaks During Dynamic Object Creation in Delphi
  2. · Creating and Destroying Components in Delphi
  3. · Changing the Code
  4. · No Except Statement?

print this article
SEARCH DEVARTICLES

TOOLS YOU CAN USE

advertisement
Using Try and Finally to Help Prevent Memory Leaks During Dynamic Object Creation in Delphi - Creating and Destroying Components in Delphi
(Page 2 of 4 )

If the object created during runtime is not freed properly, the memory remains occupied but the application can longer free it, leading to an access violation error. A memory leak may go on filling the available memory, degrading the performance considerably even if it doesn't actually crash the system. But let's first take a look at how a component is created and destroyed during runtime in Delphi. You can call a constructor method with or without parameters to create its instance and later free it explicitly. In the code that follows I am creating a local variable as an object reference to an instance of TTable, performing database transaction and freeing it.

var
  
Tbl1:TTable;

begin
  
Tbl1:=TTable.Create(nil);
  
Tbl1.Databasename:='EmployeesDB';
  
Tbl1.TableName:='Employees';
  
Tbl1.Open;
  
Tbl1.Insert;
  
Tbl1.FieldByName('Employee_Name').AsString:=EditEmpName.Text;
  
Tbl1.Post;
  
Tbl1.Free;
end;

This works fine as long as none of the statements occurring between the Create and the Free methods cause error. If they do the process terminates, but the memory allocated to Tbl1 is not freed and we have a resource leak at hand. Memory leaks in Delphi can turn into a real nightmare; you can take my word on it.

This situation can be avoided, however, by putting the code in "try/finally" blocks. A try/finally statement consists of two blocks of statements. The first "try" block consists of statements which may raise exceptions, while the finally block contains statements that should be executed regardless of whether the statements in the try block raised errors or not. You can put the database transaction code in the try block and free the object in the finally block so that it is executed even if the database transaction ends in an error.


blog comments powered by Disqus
DELPHI-KYLIX ARTICLES

- Loading an XML Document into the DOM
- Delphi Wrapper Classes and XML
- Delphi and the DOM
- Delphi and XML
- Internet Access: Client Service
- Finishing the Client for an Internet Access ...
- The Client for an Internet Access Control Ap...
- User Management for an Internet Access Contr...
- Important Procedures for an Internet Access ...
- Server Code for an Internet Access Control A...
- Constructing the Interface for an Internet A...
- Building a Server Application for an Interne...
- Building an Internet Access Control Applicat...
- Client Dataset: Working with Data Packets an...
- Using the Client Dataset in an N-Tiered Appl...

Dev Articles Forums 
 RSS  Articles
 RSS  Forums
 RSS  All Feeds
Weekly Newsletter
 
Developer Updates  
Free Website Content 
Contact Us 
Site Map 
Privacy Policy 
Support 



© 2003-2012 by Developer Shed. All rights reserved. DS Cluster 5 - Follow our Sitemap
Popular Web Development Topics
All Web Development Tutorials