aboutsummaryrefslogtreecommitdiffstats
path: root/docs/progGuideDB
diff options
context:
space:
mode:
Diffstat (limited to 'docs/progGuideDB')
-rw-r--r--docs/progGuideDB/implementation.xml49
1 files changed, 49 insertions, 0 deletions
diff --git a/docs/progGuideDB/implementation.xml b/docs/progGuideDB/implementation.xml
index fcf05583a..96939d29a 100644
--- a/docs/progGuideDB/implementation.xml
+++ b/docs/progGuideDB/implementation.xml
@@ -217,6 +217,55 @@
</sect2>
+ <sect2>
+ <title>Initializers and Inter-type Constructors</title>
+
+ <para>
+ The code for Java initializers, such as the assignment to the
+ field d in
+ </para>
+
+<programlisting><![CDATA[
+ class C {
+ double d = Math.sqrt(2);
+ }
+]]></programlisting>
+
+ <para>
+ are considered part of constructors by the time AspectJ gets ahold
+ of bytecode. That is, the assignment of d to the square root of
+ two happens <emphasis>inside</emphasis> the default constructor of
+ C.
+ </para>
+
+ <para>
+ Thus inter-type constructors will not necessarily run a target
+ type's initialization code. In particular, if the inter-type
+ constructor calls a super-constructor (as opposed to a
+ <literal>this</literal> constructor), the target type's
+ initialization code will <emphasis>not</emphasis> be run when that
+ inter-type constructor is called.
+ </para>
+
+<programlisting><![CDATA[
+ aspect A {
+ C.new(Object o) {} // implicitly calls super()
+
+ public static void main(String[] args) {
+ System.out.println((new C() ).d); // prints 1.414...
+ System.out.println((new C(null)).d); // prints 0.0
+ }
+]]></programlisting>
+
+ <para>
+ It is the job of an inter-type constructor to do all the required
+ initialization, or to delegate to a <literal>this</literal>
+ constructor if necessary.
+ </para>
+
+ </sect2>
+
+
</sect1>
</appendix>