source: trunk/doc/src/objectmodel/objecttrees.qdoc@ 815

Last change on this file since 815 was 651, checked in by Dmitry A. Kuminov, 16 years ago

trunk: Merged in qt 4.6.2 sources.

  • Property svn:eol-style set to native
File size: 5.6 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2010 Nokia Corporation and/or its subsidiary(-ies).
4** All rights reserved.
5** Contact: Nokia Corporation (qt-info@nokia.com)
6**
7** This file is part of the documentation of the Qt Toolkit.
8**
9** $QT_BEGIN_LICENSE:LGPL$
10** Commercial Usage
11** Licensees holding valid Qt Commercial licenses may use this file in
12** accordance with the Qt Commercial License Agreement provided with the
13** Software or, alternatively, in accordance with the terms contained in
14** a written agreement between you and Nokia.
15**
16** GNU Lesser General Public License Usage
17** Alternatively, this file may be used under the terms of the GNU Lesser
18** General Public License version 2.1 as published by the Free Software
19** Foundation and appearing in the file LICENSE.LGPL included in the
20** packaging of this file. Please review the following information to
21** ensure the GNU Lesser General Public License version 2.1 requirements
22** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
23**
24** In addition, as a special exception, Nokia gives you certain additional
25** rights. These rights are described in the Nokia Qt LGPL Exception
26** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you have questions regarding the use of this file, please contact
37** Nokia at qt-info@nokia.com.
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42/*!
43 \page objecttrees.html
44 \title Object Trees and Object Ownership
45 \brief Information about the parent-child pattern used to describe
46 object ownership in Qt.
47
48 \section1 Overview
49
50 \link QObject QObjects\endlink organize themselves in object trees.
51 When you create a QObject with another object as parent, it's added to
52 the parent's \link QObject::children() children() \endlink list, and
53 is deleted when the parent is. It turns out that this approach fits
54 the needs of GUI objects very well. For example, a \l QShortcut
55 (keyboard shortcut) is a child of the relevant window, so when the
56 user closes that window, the shorcut is deleted too.
57
58 \l QWidget, the base class of everything that appears on the screen,
59 extends the parent-child relationship. A child normally also becomes a
60 child widget, i.e. it is displayed in its parent's coordinate system
61 and is graphically clipped by its parent's boundaries. For example,
62 when the application deletes a message box after it has been
63 closed, the message box's buttons and label are also deleted, just as
64 we'd want, because the buttons and label are children of the message
65 box.
66
67 You can also delete child objects yourself, and they will remove
68 themselves from their parents. For example, when the user removes a
69 toolbar it may lead to the application deleting one of its \l QToolBar
70 objects, in which case the tool bar's \l QMainWindow parent would
71 detect the change and reconfigure its screen space accordingly.
72
73 The debugging functions \l QObject::dumpObjectTree() and \l
74 QObject::dumpObjectInfo() are often useful when an application looks or
75 acts strangely.
76
77 \target note on the order of construction/destruction of QObjects
78 \section1 Construction/Destruction Order of QObjects
79
80 When \l {QObject} {QObjects} are created on the heap (i.e., created
81 with \e new), a tree can be constructed from them in any order, and
82 later, the objects in the tree can be destroyed in any order. When any
83 QObject in the tree is deleted, if the object has a parent, the
84 destructor automatically removes the object from its parent. If the
85 object has children, the destructor automatically deletes each
86 child. No QObject is deleted twice, regardless of the order of
87 destruction.
88
89 When \l {QObject} {QObjects} are created on the stack, the same
90 behavior applies. Normally, the order of destruction still doesn't
91 present a problem. Consider the following snippet:
92
93 \snippet doc/src/snippets/code/doc_src_objecttrees.qdoc 0
94
95 The parent, \c window, and the child, \c quit, are both \l {QObject}
96 {QObjects} because QPushButton inherits QWidget, and QWidget inherits
97 QObject. This code is correct: the destructor of \c quit is \e not
98 called twice because the C++ language standard \e {(ISO/IEC 14882:2003)}
99 specifies that destructors of local objects are called in the reverse
100 order of their constructors. Therefore, the destructor of
101 the child, \c quit, is called first, and it removes itself from its
102 parent, \c window, before the destructor of \c window is called.
103
104 But now consider what happens if we swap the order of construction, as
105 shown in this second snippet:
106
107 \snippet doc/src/snippets/code/doc_src_objecttrees.qdoc 1
108
109 In this case, the order of destruction causes a problem. The parent's
110 destructor is called first because it was created last. It then calls
111 the destructor of its child, \c quit, which is incorrect because \c
112 quit is a local variable. When \c quit subsequently goes out of scope,
113 its destructor is called again, this time correctly, but the damage has
114 already been done.
115*/
Note: See TracBrowser for help on using the repository browser.