Sophie

Sophie

distrib > Mandriva > 2009.1 > x86_64 > media > main-backports > by-pkgid > ec081eb1f0fb87b7640153d3a3340fac > files > 56

mono-doc-2.4.2.2-1mdv2009.1.x86_64.rpm

<?xml version="1.0" encoding="us-ascii"?><span>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
   <title>mono-api-gchandle.html</title>
   <style type="text/css">


   h3 { 
       font-size: 18px;
       padding-bottom: 4pt;
       border-bottom: 2px solid #dddddd;
   }
       
   .api {
     border: 1px solid;
     padding: 10pt;
     margin: 10pt;
   } 

   .api-entry { 
       border-bottom: none;
       font-size: 18px;
   }

   .prototype {
     border: 1px solid;
     background-color: #f2f2f2;
     padding: 5pt;
     margin-top: 5pt;
     margin-bottom: 5pt;  
   } 

   .header {
     border: 1px solid;
     padding: 0 0 5pt 5pt;
     margin: 10pt;
     white-space: pre;
       font-family: monospace;
   }
    
   .code {
     border: 1px solid;
     padding: 0 0 5pt 5pt;
     margin: 10pt;
     white-space: pre;
       font-family: monospace;
   }
   

</style>
</head>
<body>
<h1>GC Handles</h1>

<h3>Synopsys</h3>

	<div class="header">
guint32     <a href="#api:mono_gchandle_new">mono_gchandle_new</a>          (MonoObject *obj, 
                                        gboolean pinned);
guint32     <a href="#api:mono_gchandle_new_weakref">mono_gchandle_new_weakref</a>  (MonoObject *obj, 
                                        gboolean track_resurrection);
MonoObject* <a href="#api:mono_gchandle_get_target">mono_gchandle_get_target</a>   (guint32 gchandle);
gboolean    <a href="#api:mono_gchandle_is_in_domain">mono_gchandle_is_in_domain</a> (guint32 gchandle, 
                                        MonoDomain *domain);
void        <a href="#api:mono_gchandle_free">mono_gchandle_free</a>         (guint32 gchandle);

	</div>
	
	<p />GC handles are wrappers that are used to keep references to
	managed objects in the unmanaged space and preventing the
	object from being disposed.
	
	<p />These are the C equivalents of the <tt>System.GCHandle</tt>
	structure.

	<p />There are two kinds of GCHandles that can be created:

	<ul>
		<li>Handles to objects (use <tt><a href="#api:mono_gchandle_new">mono_gchandle_new</a></tt>). 

		<li>Weak handles to objects (use <tt><a href="#api:mono_gchandle_new_weakref">mono_gchandle_new_weakref</a></tt>).
		Weak handles can have the objects reclaimed by the
		garbage collector. 
		
	</li></li></ul>

	<p />To retrieve the target address of an object pointed to by a
	<tt>GCHandle</tt> you should use
	<tt>mono_gchandle_get_target</tt>.

	<p />For example, consider the following C code:
<div class="code">
static MonoObject* o = NULL;
</div>

	<p />The object in `o' will *NOT* be scanned.

	<p />If you need to store an object in a C variable and prevent
	it from being collected, you need to acquire a GC handle for
	it.

<div class="code">
        guint32 handle = mono_gchandle_new (my_object, TRUE);
</div>

	<p />TRUE means the object will be pinned, so it won't move in
	memory when we'll use a moving GC. You can access the
	MonoObject* referenced by a handle with:

<div class="code">
        MonoObject* obj = mono_gchandle_get_target (handle);
</div>

	<p />When you don't need the handle anymore you need to call:

<div class="code">
        mono_gchandle_free (handle);
</div>

	<p />Note that if you assign a new object to the C var, you need
	to get a new handle, it's not enough to store a new object in
	the C var.

	<p />So code that looked like this:

<div class="code">
        static MonoObject* o = NULL;
        ...
        o = mono_object_new (...);
        /* use o */
        ...
        /* when done to allow the GC to collect o */
        o = NULL;
</div>

	<p />should now be changed to:

<div class="code">
        static guint32 o_handle;
        ...
        MonoObject *o = mono_object_new (...);
        o_handle = mono_gchandle_new (o, TRUE);
        /* use o or mono_gchandle_get_target (o_handle) */
        ...
        /* when done to allow the GC to collect o */
        mono_gchandle_free (o_handle);
</div>
		
 <a name="api:mono_gchandle_new"></a>
 <div class="api">
    <div class="api-entry">mono_gchandle_new</div>

    <div class="prototype">guint32
mono_gchandle_new (MonoObject *obj, gboolean pinned)

</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>obj:</i></dt><dd> managed object to get a handle for</dd><dt><i>pinned:</i></dt><dd> whether the object should be pinned</dd></blockquote>
<b>Returns</b>
<blockquote>	  a handle that can be used to access the object from

	 unmanaged code.</blockquote>
<b>Remarks</b>
<p />	 
	 This returns a handle that wraps the object, this is used to keep a
	 reference to a managed object from the unmanaged world and preventing the
	 object from being disposed.
	
<p />
	 If <i>pinned</i> is false the address of the object can not be obtained, if it is
	 true the address of the object can be obtained.  This will also pin the
	 object so it will not be possible by a moving garbage collector to move the
	 object. 
	
<p />

</div> <a name="api:mono_gchandle_new_weakref"></a>
 <div class="api">
    <div class="api-entry">mono_gchandle_new_weakref</div>

    <div class="prototype">guint32
mono_gchandle_new_weakref (MonoObject *obj, gboolean track_resurrection)

</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>obj:</i></dt><dd> managed object to get a handle for</dd><dt><i>pinned:</i></dt><dd> whether the object should be pinned</dd></blockquote>
<b>Returns</b>
<blockquote>	  a handle that can be used to access the object from

	 unmanaged code.</blockquote>
<b>Remarks</b>
<p />	 
	 This returns a weak handle that wraps the object, this is used to
	 keep a reference to a managed object from the unmanaged world.
	 Unlike the mono_gchandle_new the object can be reclaimed by the
	 garbage collector.  In this case the value of the GCHandle will be
	 set to zero.
	
<p />
	 If <i>pinned</i> is false the address of the object can not be obtained, if it is
	 true the address of the object can be obtained.  This will also pin the
	 object so it will not be possible by a moving garbage collector to move the
	 object. 
	
<p />

</div> <a name="api:mono_gchandle_get_target"></a>
 <div class="api">
    <div class="api-entry">mono_gchandle_get_target</div>

    <div class="prototype">MonoObject*
mono_gchandle_get_target (guint32 gchandle)

</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>gchandle:</i></dt><dd> a GCHandle's handle.</dd></blockquote>
<b>Remarks</b>
<p />	 
	 The handle was previously created by calling mono_gchandle_new or
	 mono_gchandle_new_weakref. 
	
	 Returns a pointer to the MonoObject represented by the handle or
	 NULL for a collected object if using a weakref handle.

</div> <a name="api:mono_gchandle_is_in_domain"></a>
 <div class="api">
    <div class="api-entry">mono_gchandle_is_in_domain</div>

    <div class="prototype">gboolean
mono_gchandle_is_in_domain (guint32 gchandle, MonoDomain *domain)

</div>
<p />
<b>Parameters</b>
<blockquote><dt><i>gchandle:</i></dt><dd> a GCHandle's handle.</dd><dt><i>domain:</i></dt><dd> An application domain.</dd></blockquote>
<b>Returns</b>
<blockquote>	  true if the object wrapped by the <i>gchandle</i> belongs to the specific <i>domain</i>.
</blockquote>

</div></body>
</html>
</span>