Error » Certification & Programming center Error !! » Programming tutorials » C++: Destructor

Programming tutorials All Knowledge Info and links to posted here

Post New Thread Reply
  C++: Destructor
LinkBack Thread Tools Display Modes
Old 03-Dec-2006, 11:27 PM   #1 (permalink)
Administrator
 
Admin's Avatar

Posts: 876
Join Date: Oct 2005
Rep Power: 10 Admin has disabled reputation

IM:
Default C++: Destructor

The implementation of C++'s Destructor efficiently

When writting a destructor it is important to understand why and what before just writting it.
*a structure and pointer recipe are on the way to explain anything thing complex here.
The point or rather to not point. A destructor removes pointers in the case of manually watching your memory leak. This method is automaticlally called whenever an object loses scope.

Scope - part of the code (eg, method, class, etc) in which a variable or parameter can be accessed.

thus, it takes care of all local and dynamic variables for us, preventing memory leak if it is written properly.

*The example will be written as if it were inside a class which has a structure within it implementing a linked list by the pointer:
Next* next;
which of course the struct is called Next.

Destructor Syntax:


~Destructor() {}


-A destructor never takes any parameters, it's only parameter is the implied one accesable by this.
-always starts with a ~, tild or tilda as it in known

now within a structure iplementing a linked list this becomes the most crucial part of your code. The structure not only has things pointing to it, but it is pointing to other objects of it's own type. These all need to be handled dynamically, but how?
*I said earlier that C++ will call this for every object, but we have no way to be sure that it will be efficient and call them in the reverse order they are pointing in! if we were to delete the lead pointer only it is possible that C++ would accept this as a completed destruction, which is not true!!
As long as the other pointers and objects are linked, the memory is not freed and we have memory leak.

So we need to delete all pointers below the current this object to insure a proper destruciton. If all goes well each object will only destroy one pointer, but we cannot be sure of this.

This will require a loop and a temp variable (which we will also destroy at the end of the destructor)

Complete Linked List Destructor:
*within the Next structure, so it gets the title of it's class or struct.

Code:
 
~Next(){ 
   Next* n = this->next; 
   Next* nn = NULL; 
   while(n){ 
      nn = n->next; 
      delete n; 
      n = nn; 
   } 
   nn = NULL; 
   n = NULL; 
}
-This loop is based on n which is true as long as n is not NULL (eg there is another Next object in the linked list)
this code itterates through the linked list objects and deletes the pointers 1 by 1, once finished with all pointers below itself setting the temporary variables to NULL, which will allow the GC or Garbage Collector to destroy them.

This example is meant to improve your knowledge of memory leak, the less leakage there is in your own programs the better, because we all know that Operating Systems are not leak free, so the more help we can give them, the better!!
Admin is offline  
Digg this Post!Add Post to del.icio.usBookmark Post in TechnoratiFurl this Post!Spurl this Post!Reddit!
Reply With Quote
   


   
Post New Thread Reply


Currently Active Users Viewing This Thread: 1 (0 members and 1 guests)
 
Thread Tools
Display Modes

Posting Rules
You may not post new threads
You may not post replies
You may not post attachments
You may not edit your posts

BB code is On
Smilies are On
[IMG] code is On
HTML code is Off
Trackbacks are On
Pingbacks are On
Refbacks are On
Forum Jump


All times are GMT -8. The time now is 10:35 AM.

Powered by vBulletin® Version 3.7.2
Copyright ©2000 - 2008, Jelsoft Enterprises Ltd.
Search Engine Friendly URLs by vBSEO 3.2.0

DMCA Policy

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228