⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 garbage-collection.html

📁 gcc手册
💻 HTML
字号:
<html lang="en">

<head>

<title>Using the GNU Compiler Collection (GCC)</title>

<meta http-equiv="Content-Type" content="text/html">

<meta name="description" content="Using the GNU Compiler Collection (GCC)">

<meta name="generator" content="makeinfo 4.3">

<link href="http://www.gnu.org/software/texinfo/" rel="generator-home">

<!--

Copyright &copy; 1988, 1989, 1992, 1993, 1994, 1995, 1996, 1997, 1998,

1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc.



   <p>Permission is granted to copy, distribute and/or modify this document

under the terms of the GNU Free Documentation License, Version 1.2 or

any later version published by the Free Software Foundation; with the

Invariant Sections being "GNU General Public License" and "Funding

Free Software", the Front-Cover texts being (a) (see below), and with

the Back-Cover Texts being (b) (see below).  A copy of the license is

included in the section entitled "GNU Free Documentation License".



   <p>(a) The FSF's Front-Cover Text is:



   <p>A GNU Manual



   <p>(b) The FSF's Back-Cover Text is:



   <p>You have freedom to copy and modify this GNU Manual, like GNU

     software.  Copies published by the Free Software Foundation raise

     funds for GNU development.-->

</head>

<body>

<div class="node">

<p>

Node:<a name="Garbage%20Collection">Garbage Collection</a>,

Next:<a rel="next" accesskey="n" href="Constant-string-objects.html#Constant%20string%20objects">Constant string objects</a>,

Previous:<a rel="previous" accesskey="p" href="Type-encoding.html#Type%20encoding">Type encoding</a>,

Up:<a rel="up" accesskey="u" href="Objective-C.html#Objective-C">Objective-C</a>

<hr><br>

</div>



<h3 class="section">Garbage Collection</h3>



   <p>Support for a new memory management policy has been added by using a

powerful conservative garbage collector, known as the

Boehm-Demers-Weiser conservative garbage collector.  It is available from

<a href="http://www.hpl.hp.com/personal/Hans_Boehm/gc/">http://www.hpl.hp.com/personal/Hans_Boehm/gc/</a>.



   <p>To enable the support for it you have to configure the compiler using an

additional argument, <code>--enable-objc-gc</code>.  You need to have

garbage collector installed before building the compiler.  This will

build an additional runtime library which has several enhancements to

support the garbage collector.  The new library has a new name,

<code>libobjc_gc.a</code> to not conflict with the non-garbage-collected

library.



   <p>When the garbage collector is used, the objects are allocated using the

so-called typed memory allocation mechanism available in the

Boehm-Demers-Weiser collector.  This mode requires precise information on

where pointers are located inside objects.  This information is computed

once per class, immediately after the class has been initialized.



   <p>There is a new runtime function <code>class_ivar_set_gcinvisible()</code>

which can be used to declare a so-called <dfn>weak pointer</dfn>

reference.  Such a pointer is basically hidden for the garbage collector;

this can be useful in certain situations, especially when you want to

keep track of the allocated objects, yet allow them to be

collected.  This kind of pointers can only be members of objects, you

cannot declare a global pointer as a weak reference.  Every type which is

a pointer type can be declared a weak pointer, including <code>id</code>,

<code>Class</code> and <code>SEL</code>.



   <p>Here is an example of how to use this feature.  Suppose you want to

implement a class whose instances hold a weak pointer reference; the

following class does this:



<pre class="example">     

     @interface WeakPointer : Object

     {

         const void* weakPointer;

     }

     

     - initWithPointer:(const void*)p;

     - (const void*)weakPointer;

     @end

     

     

     @implementation WeakPointer

     

     + (void)initialize

     {

       class_ivar_set_gcinvisible (self, "weakPointer", YES);

     }

     

     - initWithPointer:(const void*)p

     {

       weakPointer = p;

       return self;

     }

     

     - (const void*)weakPointer

     {

       return weakPointer;

     }

     

     @end

     

     </pre>



   <p>Weak pointers are supported through a new type character specifier

represented by the <code>!</code> character.  The

<code>class_ivar_set_gcinvisible()</code> function adds or removes this

specifier to the string type description of the instance variable named

as argument.



   </body></html>



⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -