Join Now
Quality Rating:
  • Currently 0.0 / 5
(0.0 / 5 - 0 votes cast)
Expertise Level:
  • Currently 0.0 / 5
(0.0 / 5 - 0 votes cast)

This page was last modified 12:05, 12 December 2007.

Cleanup stack support for non-CBase classes

From Forum Nokia Wiki

The discussion of clean up so far has assumed objects to be cleaned up are derived from CBase, with clean up by invoking delete. Other classes need explicit cleanup support to be provided by the programmer.

The cleanup stack supports other types of object by two further overloaded versions of CleanupStack::PushL(). You may push:

  • a TAny*: such objects are destroyed by invoking User::Free() on the pointer pushed — note that this is less powerful: it simply frees the memory, without calling the C++ destructor
  • a TCleanupItem: an object of this type encapsulates a pointer to the object to be pushed, and a pointer to a function that provides cleanup for that object.

Some utility functions are provided that make construction of a suitable TCleanupItem easy.


Example: RPointerArray

RPointerArray can be pushed in the CleanupStack and safely destroyed by making a TCleanupItem and a static function for it. In this example the array contains HBufC descriptors.

// static cleanup function
static void PointerArrayCleanup( TAny* aArray )
    {
    static_cast<RPointerArray<HBufC>*>( aArray )->ResetAndDestroy();
    }
 
RPointerArray<HBufC> array;
...
TCleanupItem arrayCleanup( PointerArrayCleanup, &array );
CleanupStack::PushL( arrayCleanup );
...
CleanupStack::PopAndDestroy(); // arrayCleanup
 
Powered by MediaWiki
     
     RDF Facets:
     
     
     qfnZtypeQUqfnTypeZCommunityContentQ
     qfnZtypeQUqfnTypeZWebpageQ
     qfnZtypeQUqfnTypeZWikiContentQ
     qmarsZlanguageQUxhttpE3aE2fE2fswE2enokiaE2ecomE2flanguageE2d1E2fenX