In computer programming, run-time type information or run-time type identification (RTTI) is a feature of some programming languages (such as
C++,
Object Pascal
Object Pascal is an extension to the programming language Pascal (programming language), Pascal that provides object-oriented programming (OOP) features such as Class (computer programming), classes and Method (computer programming), methods.
T ...
, and
Ada) that exposes information about an object's
data type
In computer science and computer programming, a data type (or simply type) is a collection or grouping of data values, usually specified by a set of possible values, a set of allowed operations on these values, and/or a representation of these ...
at
runtime. Run-time type information may be available for all types or only to types that explicitly have it (as is the case with Ada). Run-time type information is a specialization of a more general concept called
type introspection
In computing, type introspection is the ability of a program to ''examine'' the type or properties of an object
at runtime.
Some programming languages possess this capability.
Introspection should not be confused with reflection, which goes a ...
.
In the original C++ design,
Bjarne Stroustrup did not include run-time type information, because he thought this mechanism was often misused.
Overview
In C++, RTTI can be used to do safe
typecasts using the
dynamic_cast<>
operator, and to manipulate type information at runtime using the
typeid
operator and
std::type_info
class. In Object Pascal, RTTI can be used to perform safe type casts with the
as
operator, test the class to which an object belongs with the
is
operator, and manipulate type information at run time with classes contained in the
RTTI
unit (i.e. classes: ''TRttiContext'', ''TRttiInstanceType'', etc.). In Ada, objects of tagged types also store a type tag, which permits the identification of the type of these object at runtime. The
in
operator can be used to test, at runtime, if an object is of a specific type and may be safely converted to it.
RTTI is available only for classes that are
polymorphic, which means they have at least one
virtual method. In practice, this is not a limitation because base classes must have a
virtual destructor to allow objects of derived classes to perform proper cleanup if they are deleted from a base pointer.
Some compilers have flags to disable RTTI. Using these flags may reduce the overall size of the application, making them especially useful when targeting systems with a limited amount of memory.
C++ – ''typeid''
The
typeid
reserved word
In a programming language, a reserved word (sometimes known as a reserved identifier) is a word that cannot be used by a programmer as an identifier, such as the name of a variable, function, or label – it is "reserved from use". In brief, an '' ...
(keyword) is used to determine the
class
Class, Classes, or The Class may refer to:
Common uses not otherwise categorized
* Class (biology), a taxonomic rank
* Class (knowledge representation), a collection of individuals or objects
* Class (philosophy), an analytical concept used d ...
of an
object at runtime. It returns a
reference
A reference is a relationship between objects in which one object designates, or acts as a means by which to connect to or link to, another object. The first object in this relation is said to ''refer to'' the second object. It is called a ''nam ...
to
std::type_info
object, which exists until the end of the program. The use of
typeid
, in a non-polymorphic context, is often preferred over
dynamic_cast<''class_type''>
in situations where just the class information is needed, because
typeid
is always a
constant-time procedure, whereas
dynamic_cast
may need to traverse the class derivation lattice of its argument at runtime. Some aspects of the returned object are implementation-defined, such as
std::type_info::name()
, and cannot be relied on across compilers to be consistent.
Objects of class
std::bad_typeid
are thrown when the expression for
typeid
is the result of applying the unary * operator on a
null pointer
In computing, a null pointer (sometimes shortened to nullptr or null) or null reference is a value saved for indicating that the Pointer (computer programming), pointer or reference (computer science), reference does not refer to a valid Object (c ...
. Whether an exception is thrown for other null reference arguments is implementation-dependent. In other words, for the exception to be guaranteed, the expression must take the form
typeid(*p)
where
p
is any expression resulting in a null pointer.
Example
#include
#include
class Person ;
class Employee : public Person ;
int main()
Output (exact output varies by system and compiler):
Person
Employee
Person*
Employee
Employee
C++ – ''dynamic_cast'' and Java cast
The
dynamic_cast
operator in
C++ is used for
downcasting a reference or pointer to a more specific type in the
class hierarchy. Unlike the
static_cast
, the target of the
dynamic_cast
must be a
pointer or
reference
A reference is a relationship between objects in which one object designates, or acts as a means by which to connect to or link to, another object. The first object in this relation is said to ''refer to'' the second object. It is called a ''nam ...
to
class
Class, Classes, or The Class may refer to:
Common uses not otherwise categorized
* Class (biology), a taxonomic rank
* Class (knowledge representation), a collection of individuals or objects
* Class (philosophy), an analytical concept used d ...
. Unlike
static_cast
and
C-style typecast (where type check occurs while compiling), a type safety check is performed at runtime. If the types are not compatible, an
exception will be thrown (when dealing with
references
A reference is a relationship between Object (philosophy), objects in which one object designates, or acts as a means by which to connect to or link to, another object. The first object in this relation is said to ''refer to'' the second object. ...
) or a
null pointer
In computing, a null pointer (sometimes shortened to nullptr or null) or null reference is a value saved for indicating that the Pointer (computer programming), pointer or reference (computer science), reference does not refer to a valid Object (c ...
will be returned (when dealing with
pointers).
A
Java
Java is one of the Greater Sunda Islands in Indonesia. It is bordered by the Indian Ocean to the south and the Java Sea (a part of Pacific Ocean) to the north. With a population of 156.9 million people (including Madura) in mid 2024, proje ...
typecast behaves similarly; if the object being cast is not actually an instance of the target type, and cannot be converted to one by a language-defined method, an instance of
java.lang.ClassCastException
will be thrown.
Example
Suppose some
function takes an
object of type
A
as its argument, and wishes to perform some additional operation if the object passed is an instance of
B
, a
subclass of
A
. This can be done using
dynamic_cast
as follows.
#include
#include
#include
#include
using namespace std;
class A ;
class B: public A ;
void MyFunction(A& my_a)
int main()
Console output:
Method specific for B was invoked
Method specific for B was invoked
Exception std::bad_cast thrown.
Object is not of type B
A similar version of
MyFunction
can be written with
pointers instead of
references
A reference is a relationship between Object (philosophy), objects in which one object designates, or acts as a means by which to connect to or link to, another object. The first object in this relation is said to ''refer to'' the second object. ...
:
void MyFunction(A* my_a)
Object Pascal, Delphi
In Object Pascal and
Delphi
Delphi (; ), in legend previously called Pytho (Πυθώ), was an ancient sacred precinct and the seat of Pythia, the major oracle who was consulted about important decisions throughout the ancient Classical antiquity, classical world. The A ...
, the operator
is
is used to check the type of a class at runtime. It tests the belonging of an object to a given class, including classes of individual ancestors present in the inheritance hierarchy tree (e.g. ''Button1'' is a ''TButton'' class that has ancestors: ''TWinControl'' → ''TControl'' → ''TComponent'' → ''TPersistent'' → ''TObject'', where the latter is the ancestor of all classes). The operator
as
is used when an object needs to be treated at run time as if it belonged to an ancestor class.
The RTTI unit is used to manipulate object type information at run time. This unit contains a set of classes that allow you to: get information about an object's class and its ancestors, properties, methods and events, change property values and call methods. The following example shows the use of the RTTI module to obtain information about the class to which an object belongs, creating it, and to call its method. The example assumes that the TSubject class has been declared in a unit named SubjectUnit.
uses
RTTI, SubjectUnit;
procedure WithoutReflection;
var
MySubject: TSubject;
begin
MySubject := TSubject.Create;
try
Subject.Hello;
finally
Subject.Free;
end;
end;
procedure WithReflection;
var
RttiContext: TRttiContext;
RttiType: TRttiInstanceType;
Subject: TObject;
begin
RttiType := RttiContext.FindType('SubjectUnit.TSubject') as TRttiInstanceType;
Subject := RttiType.GetMethod('Create').Invoke(RttiType.MetaclassType, []).AsObject;
try
RttiType.GetMethod('Hello').Invoke(Subject, []);
finally
Subject.Free;
end;
end;
See also
* Type inference
* Type introspection
*
typeof
*
Reflection (computer science)
*
Template (C++)
References
External links
dynamic_cast
operator at IBM Mac OS X Compilersdynamic_cast
operator at MSDN
{{DEFAULTSORT:Run-Time Type Information
C++
Class (computer programming)
Data types
Programming language comparisons
Articles with example C++ code
Articles with example Java code
Articles with example Pascal code