System.TObject.Destroy

From RAD Studio VCL Reference
Jump to: navigation, search

Contents

Delphi Information

From System.pas

	destructor Destroy();


Unit: System

Type: destructor

Visibility: public

Member Of: TObject

C++ Information

From System.hpp

	virtual void __fastcall ~TObject(void);


Unit: System

Type: destructor

Visibility: public

Member Of: TObject

Description

Disposes of an object instance.


Do not call Destroy directly. Call Free instead. Free verifies that the object reference is not nil before calling Destroy.

The Destroy method defined by TObject deallocates memory. Descendant objects usually define a destructor that is customized for that particular kind of object.

When declaring a Destroy method in a descendant, always add the override directive to the declaration and call the inherited Destroy as the last statement in the overriding method. Since Destroy is a virtual method, overriding it ensures that the proper inherited behavior occurs.

Note:  If an exception escapes from the constructor, the destructor is called to destroy the partially constructed object instance that failed to initialize completely. Therefore, destructors should check that allocated resources such as handles were actually allocated before trying to release them, since their value might be zero.

Destroy should be implemented so that it calls Free on all subobjects created within the object's constructor (that is, allocated by the constructor). Unlike Destroy, Free provides a safeguard when destroying objects that are nil.

See Also

Personal tools
Translations
Newest Version