<div dir="ltr">Hi Johan,<div><br></div><div>We've been calling Object class >> _objectForOop: for a long time. We do not use weak references, but we often debug or take oops from a stack trace in a log to go and look into things.</div><div><br></div><div>When an object does not exist, the method has always returned nil. I've never seen an exception thrown when calling _objectForOop:</div><div><br></div><div>The stack trace entry for </div><div><span style="color:rgb(68,68,68);font-family:Consolas,"Liberation Mono",Courier,monospace,EmojiFontFace;white-space:pre-wrap;background-color:rgb(248,248,248)">privateObjectAtUniqueIdentifie</span><span style="color:rgb(68,68,68);font-family:Consolas,"Liberation Mono",Courier,monospace,EmojiFontFace;white-space:pre-wrap;background-color:rgb(248,248,248)">r:in:ifAbsent:</span><br></div><div>does not tell me what is happening. Perhaps this is optimised by the compiler? How do you know that this is calling _objectForOop: and that it is _objectForOop: that raises the <span style="background-color:rgb(248,248,248);color:rgb(68,68,68);font-family:Consolas,"Liberation Mono",Courier,monospace,EmojiFontFace;white-space:pre-wrap">InternalError</span>?</div><div><br></div><div>Pardon my ignorance if I'm not following.</div><div><br></div><div>Kind regards</div><div><div><div dir="ltr" class="gmail_signature" data-smartmail="gmail_signature"><div dir="ltr"><div><div dir="ltr"><table width="600" cellpadding="0" cellspacing="0" border="0" style="color:rgb(0,0,0);font-family:Times;font-size:medium"><tbody><tr><td width="400" valign="bottom"><p style="margin:0px;padding:0px"><span style="font-size:18px;color:rgb(146,148,151);font-family:Calibri,sans-serif;font-weight:700">Otto Behrens</span><br></p><p style="font-size:18px;font-weight:700;color:rgb(146,148,151);font-family:Calibri,sans-serif;margin:0px;padding:0px"><span style="font-size:14px;font-weight:300;margin:0px;padding:0px">+27 82 809 2375</span></p></td><td width="200" valign="middle"><img src="https://www.finworks.biz/signature/finworks-signature-logo.png" width="200" height="38" alt="FINWorks" style="display:block;border:0px;width:200px;height:38px;margin:0px;padding:0px"></td></tr></tbody></table><table width="600" cellpadding="0" cellspacing="0" border="0" style="color:rgb(0,0,0);font-family:Times;font-size:medium"><tbody><tr><td height="5"></td></tr></tbody></table><table width="600" cellpadding="0" cellspacing="0" border="0" style="color:rgb(0,0,0);font-family:Times;font-size:medium;border-bottom:1px solid rgb(200,28,36)"><tbody><tr><td height="15"></td></tr></tbody></table><table width="600" cellpadding="0" cellspacing="0" border="0" style="color:rgb(0,0,0);font-family:Times;font-size:medium"><tbody><tr><td height="20"></td></tr></tbody></table><table width="600" cellpadding="0" cellspacing="0" border="0" style="color:rgb(0,0,0);font-family:Times;font-size:medium"><tbody><tr><td width="15" valign="top" style="display:inline-block"><a href="http://za.linkedin.com/in/waltherbehrens" style="color:rgb(17,85,204)" target="_blank"><img src="https://www.finworks.biz/signature/finworks-linkedin-logo.png" width="15" height="15" alt="FINWorks" style="display:inline-block;border:0px;width:15px;height:15px;margin-top:1.5px;padding:0px"></a></td><td width="250" valign="top" style="display:inline-block"><a href="http://www.finworks.biz/" style="color:rgb(200,28,36);font-family:Calibri,sans-serif;margin-left:10px;margin-top:0px;padding-top:0px;font-size:11pt;display:inline-block" target="_blank">www.finworks.biz</a></td></tr></tbody></table><table width="600" cellpadding="0" cellspacing="0" border="0" style="color:rgb(0,0,0);font-family:Times;font-size:medium"><tbody><tr><td height="10"></td></tr></tbody></table><table width="600" cellpadding="0" cellspacing="0" border="0" style="color:rgb(0,0,0);font-family:Times;font-size:medium"><tbody><tr><td><p style="font-size:10px;color:rgb(146,148,151);font-family:Calibri,sans-serif;text-align:justify">Disclaimer & Confidentiality Note: This email is intended solely for the use of the individual or entity named above as it may contain information that is confidential and privileged. If you are not the intended recipient, be advised that any dissemination, distribution or copying of this email is strictly prohibited. FINWorks cannot be held liable by any person other than the addressee in respect of any opinions, conclusions, advice or other information contained in this email.</p></td></tr></tbody></table></div></div></div></div></div><br></div></div><br><div class="gmail_quote"><div dir="ltr" class="gmail_attr">On Fri, Jul 22, 2022 at 2:29 PM Johan Brichau via GemStone-Smalltalk <<a href="mailto:gemstone-smalltalk@lists.gemtalksystems.com">gemstone-smalltalk@lists.gemtalksystems.com</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left:1px solid rgb(204,204,204);padding-left:1ex"><div style="overflow-wrap: break-word;">Hi,<div><br></div><div>We use the objectForOop: method to implement weak references but are hitting some errors while using it. </div><div>I want to better understand what we are seeing.</div><div>The following is in Gemstone 3.4.5</div><div><br></div><div>First off: we understand the dangers mentioned in the method's comment, well… to some extent otherwise I would not ask this question:-). To counter trouble with oop reuse, we also store the object creation time together with the oop (and in the referenced object). A check on class and creation timestamp allows us to guarantee when we get an object back from objectForOop: that it was the one we originally referenced or not.</div><div><br></div><div>The reason we use this concept is to implement weak references. We store log items in the database which reference a series of objects. The log item will stay in the database for a very long time but should not keep the referenced objects from being garbage collected. Hence, we store the oop (+ the creation timestamp, as mentioned) instead of the object in the log items, which would otherwise keep these from being collected in an MFC.</div><div><br></div><div>The trouble is we sometimes encounter an error after an MFC cycle has concluded.</div><div>The _objectForOop: method throws a ‘primitive failed’ that the object with object ID xxxx does not exist. See stack trace below.</div><div><br></div><div>What is interesting is that the oop in the error message is _not_ the argument passed to _objectForOop:. Instead, it is the oop of an object held in an instVar of the object we try to retrieve.</div><div>It is an instance of DateAndTime. Thus we seem to retrieve a dead object that can still be retrieved but of which the objects referenced by it are already collected and that this errors the primitive?</div><div>We tried to counter the problem of retrieving dead objects by using _oopIsDead: but only do so _after_ invoking objectForOop:. </div><div>Perhaps the straightforward solution is to first check _oopIsDead: and only then use _objectForOop: ? For now, we have wrapped it with an exception handler to handle the error.</div><div><br></div><div>Next, we saw this problem in Gemstone 2.4.4.1 as well but there it would crash the entire gem. Since our upgrade to GemStone 3.4.5, this error no longer crashes the gem and is captured by the error handler.</div><div>This, however, has now shown that because the gem continues working, the problem may occur even many hours after the MFC cycle. Is this to be expected? I understand how in between a collect and a reclaim, this may happen but not how it can still occur many hours later?</div><div><br></div><div>And finally… we are aware this is all rather hacking. Now that we finally are moving up towards the latest version of GemStone: are there better ways to implement weak references in GemStone? ;-)</div><div><br></div><div>Thanks for any thoughts!</div><div>Johan</div><div><br></div><div><span style="color:rgb(68,68,68);font-family:Consolas,"Liberation Mono",Courier,monospace,EmojiFontFace;font-variant-ligatures:normal;white-space:pre-wrap;background-color:rgb(248,248,248)">----------- Continuation saved to object log ERROR Encountered: 2022-07-22T07:29:21.16192007064819+02:00
a InternalError occurred (error 2101), The object with object ID 5754897665 does not exist.
1 GRGemStonePlatform >> logError:title:shouldCommit: @3 line 4  [GsNMethod 551003905]
2 GRGemStonePlatform >> logError:title: @2 line 3  [GsNMethod 550999041]
3 NPGemStoneErrorHandler (WAErrorHandler) >> saveExceptionContinuation: @9 line 6  [GsNMethod 603180545]
4 NPGemStoneErrorHandler >> handleDefault: @6 line 7  [GsNMethod 632646401]
5 NPGemStoneErrorHandler (WAErrorHandler) >> handleError: @2 line 2  [GsNMethod 603181313]
6 NPGemStoneErrorHandler (WAErrorHandler) >> handleGemStoneException: @5 line 4  [GsNMethod 603182081]
7 NPGemStoneErrorHandler (WAHtmlHaltAndErrorHandler) >> handleException: @2 line 2  [GsNMethod 613492481]
8 NPGemStoneErrorHandler >> handleException: @6 line 5  [GsNMethod 632646145]
9 [] in WAExceptionHandler >> handleExceptionsDuring: @11 line 5  [GsNMethod 1320949761]
10 ExecBlock0 (ExecBlock) >> on:do: @3 line 44  [GsNMethod 53734657]
11 [] in WAExceptionHandler >> handleExceptionsDuring: @7 line 8  [GsNMethod 968955649]
12 [] in ExecBlock >> on:do: @16 line 53  [GsNMethod 65134849]
13 InternalError (AbstractException) >> _executeHandler: @8 line 11  [GsNMethod 61046017]
14 InternalError (AbstractException) >> _signalFromPrimitive: @1 line 1  [GsNMethod 61048321]
15 NPLogEntry >> privateObjectAtUniqueIdentifier:in:ifAbsent: @1 line 1  [GsNMethod 651626241]
16 NPLogEntry >> originalObjectInDB:ifAbsent: @3 line 3  [GsNMethod 651630337]
17 NPLogEntry >> originalObjectInDB: @2 line 2  [GsNMethod 651613953]
18 NPLogEntry >> concernedObjectsInDB: @5 line 6  [GsNMethod 651637249]
19 NPLoggingManagerForGemStone (NPLoggingManager) >> isCurrentUserFollowingEntry: @3 line 3  [GsNMethod 623065857]
…</span></div><div><span style="color:rgb(68,68,68);font-family:Consolas,"Liberation Mono",Courier,monospace,EmojiFontFace;font-variant-ligatures:normal;white-space:pre-wrap;background-color:rgb(248,248,248)"><br></span></div></div>_______________________________________________<br>
GemStone-Smalltalk mailing list<br>
<a href="mailto:GemStone-Smalltalk@lists.gemtalksystems.com" target="_blank">GemStone-Smalltalk@lists.gemtalksystems.com</a><br>
<a href="https://lists.gemtalksystems.com/mailman/listinfo/gemstone-smalltalk" rel="noreferrer" target="_blank">https://lists.gemtalksystems.com/mailman/listinfo/gemstone-smalltalk</a><br>
</blockquote></div>