Skip to main content

IMPORTANCE OF CLEAN UP: finalization & garbage collection



To clean up an object, the user of that object must call a cleanup method at the point the cleanup is desired. This is straightforward, but it collides a bit with the C++ concept of destructor. In C++ all object is created as a local (i.e., on the stack –not possible in java), then the destruction happens at the closing curly braces of the scope in which the object was created. Programmers know about the importance of initialization, but often forget the importance of clean up. After all who need to clean up int?  Java has the garbage collector to reclaim the memory of objects that are no longer used.  Here I am considering an unusual case: let java object allocate a special memory without using new.  Garbage collector only knows how to release memory allocated with new, so it would not know how to release the special memory. To handle that type of situation /cases, java provides a method called finalize () that define in the class.
How it is supposed to work & What the finalize() for ?
When garbage collector is ready to ready to release the storage used by object, it will first call finalize(), and only on the next garbage-collection pass will it reclaim the object’s memory.  So if we use finalize (), it gives the ability to perform cleanup at the time of garbage collection. The C++ programmers, might initially mistake finalize () for the destructor in C++, which is a function that is always called when object is destroyed. It is important to distinguished between C++ and Java here, because in C++, objects always get destroyed , where as in Java, object do not always get garbage collected.
ð Object might not get garbage collected.
ð Garbage collection is not destruction.
Java has no destructor or similar concept, so we must create an ordinary method to perform cleanup.
ð Garbage collection is only about memory.
The existence of garbage collector is to recover memory that program no longer using.  So any activity that is associated with garbage collection, most notably finalize () method, must also be only about memory and its de-allocation.
Anurag

Comments

Popular posts from this blog

Standard and Formatted Input / Output in C++

The C++ standard libraries provide an extensive set of input/output capabilities which we will see in subsequent chapters. This chapter will discuss very basic and most common I/O operations required for C++ programming. C++ I/O occurs in streams, which are sequences of bytes. If bytes flow from a device like a keyboard, a disk drive, or a network connection etc. to main memory, this is called   input operation   and if bytes flow from main memory to a device like a display screen, a printer, a disk drive, or a network connection, etc., this is called   output operation . Standard Input and Output in C++ is done through the use of  streams . Streams are generic places to send or receive data. In C++, I/O is done through classes and objects defined in the header file  <iostream> .  iostream  stands for standard input-output stream. This header file contains definitions to objects like  cin ,  cout , etc. /O Library Header Files There are...

Normalization in DBMS: 1NF, 2NF, 3NF and BCNF in Database

Normalization   is a process of organizing the data in database to avoid data redundancy, insertion anomaly, update anomaly & deletion anomaly.  Anomalies in DBMS There are three types of anomalies that occur when the database is not normalized. These are – Insertion, update and deletion anomaly. Let’s take an example to understand this. Example : Suppose a manufacturing company stores the employee details in a table named employee that has four attributes: emp_id for storing employee’s id, emp_name for storing employee’s name, emp_address for storing employee’s address and emp_dept for storing the department details in which the employee works. At some point of time the table looks like this: emp_id emp_name emp_address emp_dept 101 Nikhil Kangra D001 101 Nikhil Kangra D002 123 Ashish Shimla D890 166 Rahul Pathankot D900 166 Rahul Pathankot D004 The above table is not normalized.  Update anomaly : In the above table we have two rows for employee Nikhil as he belongs ...

Genetic Algorithm: Population, Fitness Function, Parent Selection, Cross over, Mutation

Genetic Algo Population Population is a subset of solutions in the current generation. It can also be defined as a set of chromosomes. There are several things to be kept in mind when dealing with GA population − The diversity of the population should be maintained otherwise it might lead to premature convergence. The population size should not be kept very large as it can cause a GA to slow down, while a smaller population might not be enough for a good mating pool. Therefore, an optimal population size needs to be decided by trial and error. The population is usually defined as a two dimensional array of –  size population, size x, chromosome size . Population Initialization There are two primary methods to initialize a population in a GA. They are − Random Initialization  − Populate the initial population with completely random solutions. Heuristic initialization  − Populate the initial population using a known heuristic for the problem. It has been observed that the e...