<html xmlns:v="urn:schemas-microsoft-com:vml" xmlns:o="urn:schemas-microsoft-com:office:office" xmlns:w="urn:schemas-microsoft-com:office:word" xmlns:m="http://schemas.microsoft.com/office/2004/12/omml" xmlns="http://www.w3.org/TR/REC-html40">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=us-ascii">
<meta name="Generator" content="Microsoft Word 14 (filtered medium)">
<style><!--
/* Font Definitions */
@font-face
        {font-family:Calibri;
        panose-1:2 15 5 2 2 2 4 3 2 4;}
@font-face
        {font-family:Tahoma;
        panose-1:2 11 6 4 3 5 4 4 2 4;}
/* Style Definitions */
p.MsoNormal, li.MsoNormal, div.MsoNormal
        {margin:0in;
        margin-bottom:.0001pt;
        text-align:right;
        direction:rtl;
        unicode-bidi:embed;
        font-size:11.0pt;
        font-family:"Calibri","sans-serif";}
a:link, span.MsoHyperlink
        {mso-style-priority:99;
        color:blue;
        text-decoration:underline;}
a:visited, span.MsoHyperlinkFollowed
        {mso-style-priority:99;
        color:purple;
        text-decoration:underline;}
span.EmailStyle17
        {mso-style-type:personal;
        font-family:"Calibri","sans-serif";
        color:windowtext;}
span.EmailStyle18
        {mso-style-type:personal-reply;
        font-family:"Calibri","sans-serif";
        color:#1F497D;}
.MsoChpDefault
        {mso-style-type:export-only;
        font-size:10.0pt;}
@page WordSection1
        {size:8.5in 11.0in;
        margin:1.0in 1.25in 1.0in 1.25in;}
div.WordSection1
        {page:WordSection1;}
--></style><!--[if gte mso 9]><xml>
<o:shapedefaults v:ext="edit" spidmax="1026" />
</xml><![endif]--><!--[if gte mso 9]><xml>
<o:shapelayout v:ext="edit">
<o:idmap v:ext="edit" data="1" />
</o:shapelayout></xml><![endif]-->
</head>
<body lang="EN-US" link="blue" vlink="purple">
<div class="WordSection1">
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed"><span style="color:#1F497D">Nope, you have it right &#8211; this is fixed in the Main branch and internally it&#8217;s fixed in the 2.6 branch as well (There was a report about this from some
 internal uses of IronPython).&nbsp; &nbsp;&nbsp;Unfortunately it looks like the fix hasn&#8217;t propagated out to the 2.6 branch on CodePlex for some reason.&nbsp; I&#8217;ll try and figure out what&#8217;s going on there but either way it&#8217;ll be fixed in the next set of releases.&nbsp; If you want
 to build from source you can just add a call to CheckCleanup(); in there before the dict[new WeakObject(&#8230;)] = &#8230;&nbsp; assignment.<o:p></o:p></span></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed"><span style="color:#1F497D"><o:p>&nbsp;</o:p></span></p>
<div style="border:none;border-left:solid blue 1.5pt;padding:0in 0in 0in 4.0pt">
<div>
<div style="border:none;border-top:solid #B5C4DF 1.0pt;padding:3.0pt 0in 0in 0in">
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed"><b><span style="font-size:10.0pt;font-family:&quot;Tahoma&quot;,&quot;sans-serif&quot;">From:</span></b><span style="font-size:10.0pt;font-family:&quot;Tahoma&quot;,&quot;sans-serif&quot;"> users-bounces@lists.ironpython.com
 [mailto:users-bounces@lists.ironpython.com] <b>On Behalf Of </b>Idan Zaltzberg<br>
<b>Sent:</b> Monday, October 04, 2010 9:02 AM<br>
<b>To:</b> Discussion of IronPython<br>
<b>Subject:</b> [IronPython] Possible bug in Ipy 2.6.1 WeakDictionary<o:p></o:p></span></p>
</div>
</div>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed"><o:p>&nbsp;</o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">Hi,<o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">I'm investigating memory leakage in a Ipy 2.6.1 application.<o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">Using WinDbg I found a WeakDictionary that is only increasing in size, though most of the instances are already collected.<o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">This WeakDicitionary is used by a DelegationInfo object.<o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">&nbsp;<o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">Looking at the code, I think I found the problem:<o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">The method CheckCleanup is called the method &quot;<span style="font-size:10.0pt;font-family:&quot;Courier New&quot;;color:blue">public</span><span style="font-size:10.0pt;font-family:&quot;Courier New&quot;">
<span style="color:blue">void</span> Add(TKey key, TValue value)&quot;</span><o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed"><b>But it NOT called</b> from the indexer:<o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">&nbsp;<o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;text-autospace:none;direction:ltr;unicode-bidi:embed">
<span style="font-size:10.0pt;font-family:&quot;Courier New&quot;;color:blue">public</span><span style="font-size:10.0pt;font-family:&quot;Courier New&quot;"> TValue
<span style="color:blue">this</span>[TKey key] {</span><o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;text-autospace:none;direction:ltr;unicode-bidi:embed">
<span style="font-size:10.0pt;font-family:&quot;Courier New&quot;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <span style="color:blue">
get</span> {</span><o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;text-autospace:none;direction:ltr;unicode-bidi:embed">
<span style="font-size:10.0pt;font-family:&quot;Courier New&quot;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <span style="color:blue">
return</span> dict[key];</span><o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;text-autospace:none;direction:ltr;unicode-bidi:embed">
<span style="font-size:10.0pt;font-family:&quot;Courier New&quot;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }</span><o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;text-autospace:none;direction:ltr;unicode-bidi:embed">
<span style="font-size:10.0pt;font-family:&quot;Courier New&quot;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <span style="color:blue">
set</span> {</span><o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;text-autospace:none;direction:ltr;unicode-bidi:embed">
<span style="font-size:10.0pt;font-family:&quot;Courier New&quot;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <span style="color:green">
// If the WeakHash already holds this value as a key, it will lead to a circular-reference and result</span></span><o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;text-autospace:none;direction:ltr;unicode-bidi:embed">
<span style="font-size:10.0pt;font-family:&quot;Courier New&quot;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <span style="color:green">
// in the objects being kept alive forever. The caller needs to ensure that this cannot happen.</span></span><o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;text-autospace:none;direction:ltr;unicode-bidi:embed">
<span style="font-size:10.0pt;font-family:&quot;Courier New&quot;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; <span style="color:#2B91AF">
Debug</span>.Assert(!dict.ContainsKey(<span style="color:blue">value</span>));</span><o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;text-autospace:none;direction:ltr;unicode-bidi:embed">
<span style="font-size:10.0pt;font-family:&quot;Courier New&quot;">&nbsp;</span><o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;text-autospace:none;direction:ltr;unicode-bidi:embed">
<span style="font-size:10.0pt;font-family:&quot;Courier New&quot;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; dict[<span style="color:blue">new</span>
<span style="color:#2B91AF">WeakObject</span>(key)] = <span style="color:blue">value</span>;</span><o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;text-autospace:none;direction:ltr;unicode-bidi:embed">
<span style="font-size:10.0pt;font-family:&quot;Courier New&quot;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }</span><o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed"><span style="font-size:10.0pt;font-family:&quot;Courier New&quot;">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }</span><o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">&nbsp;<o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">Since the dictionary is populated using the indexer in DelegateInfo:<o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed"><span style="font-size:10.0pt;font-family:&quot;Courier New&quot;">_constantMap[target] =
<span style="color:blue">new</span> <span style="color:#2B91AF">WeakReference</span>(clone = (<span style="color:blue">object</span>[])_constants.Clone());</span><o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">&nbsp;<o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">This means that the &quot;version&quot; field is never updated, and the dictionary never gets cleaned up.<o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">&nbsp;<o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">Have I got something wrong here?<o:p></o:p></p>
<p class="MsoNormal" style="text-align:left;direction:ltr;unicode-bidi:embed">Thanks<o:p></o:p></p>
</div>
</div>
</body>
</html>