Contents Index Search Related Documents Previous Next
3.3.1 Object Declarations
1
An
object_declaration declares a
stand-alone
object with a given nominal subtype and, optionally, an explicit initial
value given by an initialization expression.
For
an array, task, or protected object, the
object_declaration
may include the definition of the (anonymous) type of the object.
Syntax
2/2
object_declaration
::=
defining_identifier_list : [
aliased] [
constant]
subtype_indication [:=
expression];
|
defining_identifier_list : [
aliased] [
constant]
access_definition [:=
expression];
|
defining_identifier_list : [
aliased] [
constant]
array_type_definition [:=
expression];
|
single_task_declaration
|
single_protected_declaration
3
defining_identifier_list
::=
defining_identifier {,
defining_identifier}
Name Resolution Rules
4
For an
object_declaration
with an
expression following the
compound delimiter :=, the type expected for the
expression
is that of the object.
This
expression
is called the
initialization expression.
Legality Rules
5/2
An object_declaration
without the reserved word constant declares a variable object.
If it has a subtype_indication or
an array_type_definition that defines
an indefinite subtype, then there shall be an initialization expression.
Static Semantics
6
An
object_declaration
with the reserved word
constant declares a constant object.
If
it has an initialization expression, then it is called a
full constant
declaration.
Otherwise it is called a
deferred
constant declaration. The rules for deferred constant declarations
are given in clause
7.4. The rules for full
constant declarations are given in this subclause.
7
Any declaration that includes a defining_identifier_list
with more than one defining_identifier
is equivalent to a series of declarations each containing one defining_identifier
from the list, with the rest of the text of the declaration copied for
each declaration in the series, in the same order as the list. The remainder
of this International Standard relies on this equivalence; explanations
are given for declarations with a single defining_identifier.
8/2
The
subtype_indication,
access_definition, or full type
definition of an
object_declaration
defines the nominal subtype of the object. The
object_declaration
declares an object of the type of the nominal subtype.
8.1/2
A component of an object
is said to
require late initialization if it has an access discriminant
value constrained by a per-object expression, or if it has an initialization
expression which includes a name denoting the current instance of the
type or denoting an access discriminant.
Dynamic Semantics
9/2
If a composite object declared
by an
object_declaration has an
unconstrained nominal subtype, then if this subtype is indefinite or
the object is constant the actual subtype of this object is constrained.
The constraint is determined by the bounds or discriminants (if any)
of its initial value;
the object is said to be
constrained
by its initial value.
When
not constrained by its initial value, the actual and nominal subtypes
of the object are the same.
If
its actual subtype is constrained, the object is called a
constrained
object.
10
For
an
object_declaration without an
initialization expression, any initial values for the object or its subcomponents
are determined by the
implicit initial values defined for its
nominal subtype, as follows:
11
- The implicit initial value for an
access subtype is the null value of the access type.
12
- The implicit initial (and only) value
for each discriminant of a constrained discriminated subtype is defined
by the subtype.
13
- For a (definite) composite subtype,
the implicit initial value of each component with a default_expression
is obtained by evaluation of this expression and conversion to the component's
nominal subtype (which might raise Constraint_Error — see 4.6,
“Type Conversions”), unless the
component is a discriminant of a constrained subtype (the previous case),
or is in an excluded variant (see
3.8.1). For each component
that does not have a default_expression,
any implicit initial values are those determined by the component's nominal
subtype.
14
- For a protected or task subtype, there
is an implicit component (an entry queue) corresponding to each entry,
with its implicit initial value being an empty queue.
15
The
elaboration of an
object_declaration
proceeds in the following sequence of steps:
16/2
- 1.
-
The subtype_indication, access_definition,
array_type_definition, single_task_declaration,
or single_protected_declaration
is first elaborated. This creates the nominal subtype (and the anonymous
type in the last four cases).
17
- 2.
-
If the object_declaration includes
an initialization expression, the (explicit) initial value is obtained
by evaluating the expression and converting it to the nominal subtype
(which might raise Constraint_Error — see 4.6).
18/2
- 3.
-
The object is created, and, if there is not an initialization expression,
the object is initialized by default. When
an object is initialized by default, any per-object constraints (see
3.8) are elaborated and any implicit initial
values for the object or for its subcomponents are obtained as determined
by the nominal subtype. Any initial
values (whether explicit or implicit) are assigned to the object or to
the corresponding subcomponents. As described in 5.2
and 7.6, Initialize and Adjust procedures can
be called.
19/2
- This paragraph was
deleted.4.
-
20/2
For the third
step above, evaluations and assignments are performed in an arbitrary
order subject to the following restrictions:
20.1/2
- Assignment to any part of the object
is preceded by the evaluation of the value that is to be assigned.
20.2/2
- The evaluation of a default_expression
that includes the name of a discriminant is preceded by the assignment
to that discriminant.
20.3/2
- The evaluation of the default_expression
for any component that depends on a discriminant is preceded by the assignment
to that discriminant.
20.4/2
- The assignments to any components,
including implicit components, not requiring late initialization must
precede the initial value evaluations for any components requiring late
initialization; if two components both require late initialization, then
assignments to parts of the component occurring earlier in the order
of the component declarations must precede the initial value evaluations
of the component occurring later.
21
There is no implicit initial value defined for
a scalar subtype.
In the absence of an explicit initialization,
a newly created scalar object might have a value that does not belong
to its subtype (see
13.9.1 and
H.1).
22
7 Implicit initial values
are not defined for an indefinite subtype, because if an object's nominal
subtype is indefinite, an explicit initial value is required.
23
8 As
indicated above, a stand-alone object is an object declared by an object_declaration.
Similar definitions apply to “stand-alone constant” and “stand-alone
variable.” A subcomponent of an object is not a stand-alone object,
nor is an object that is created by an allocator.
An object declared by a loop_parameter_specification,
parameter_specification, entry_index_specification,
choice_parameter_specification,
or a formal_object_declaration is
not called a stand-alone object.
24
9 The type of a stand-alone
object cannot be abstract (see 3.9.3).
Examples
25
Example of a
multiple object declaration:
26
-- the multiple object declaration
27/2
John, Paul : not null Person_Name := new Person(Sex => M); -- see 3.10.1
28
-- is equivalent to the two single object declarations in the order given
29/2
John : not null Person_Name := new Person(Sex => M);
Paul : not null Person_Name := new Person(Sex => M);
30
Examples of variable
declarations:
31/2
Count, Sum : Integer;
Size : Integer range 0 .. 10_000 := 0;
Sorted : Boolean := False;
Color_Table : array(1 .. Max) of Color;
Option : Bit_Vector(1 .. 10) := (others => True);
Hello : aliased String := "Hi, world.";
θ, φ : Float range -π .. +π;
32
Examples of constant
declarations:
33/2
Limit : constant Integer := 10_000;
Low_Limit : constant Integer := Limit/10;
Tolerance : constant Real := Dispersion(1.15);
Hello_Msg : constant access String := Hello'Access; -- see 3.10.2
Contents Index Search Related Documents Previous Next Legal