<div dir="ltr"><span style="font-size:13px">> But Krita is 300k lines (or so) and had about 30 different developers</span><br style="font-size:13px"><span style="font-size:13px">> working on it at different point of time. </span><div><br></div><div>Well to me this is a reason to have the objects lifetime cycle clear so that a new developer doesn't cause issue with it.</div><div>Now you may say the very same thing with raw pointers but i still think they cause more visibile problems that can be solved during development.</div><div>However as we said earlier there's a good approach for this (shared pointers AND weak pointers, not sharing shared pointers everywhere etc).</div><div><br><div><span style="font-size:13px">> And not only the architecture has </span><span style="font-size:13px">never been documented, it changes all the time, in such a situation, real life</span><br style="font-size:13px"><span style="font-size:13px">> kicks in, and shared pointers are just better.</span><br><div><br></div></div></div><div>I do know what you're talking about and still believe that is somewhat wrong to come to a point where you have a so large codebase with the architecture undocumented.. at least on an high level.</div><div>Especially since there are a lot of developers, a bit of coordination is needed.</div><div>I would prefer writing documentation for my own sake and the others, to have a larger base of people that can help, instead of spending more time on implementing new features with the risk of breaking something, and complicating even more the architecture, because it's undocumented.</div><div>When i approach a new project i usually go around the codebase quite a lot because i'm curious and often there's no documentation ( :-) ), so i would prefer, as i already said, having a clear memory management instead of having unpredictable object lifetime.</div><div><br></div><div>But this is me, one of the many, it's not my project so can't say much, if not what i think. </div><div>I won't try to push anyone doing anything and in result be annoying, this is not my point, i do want to help.</div><div><br></div><div>And i still went a bit offtopic as always.. :P</div><div><br></div><div><span style="font-size:13px">> This is a bug, obviously. It should assert if the weak shared pointer is not</span><br style="font-size:13px"><span style="font-size:13px">> valid.</span><br></div><div><span style="font-size:13px"><br></span></div><div>Isn't it better to have the shared pointer to be constructed but null?</div><div>I don't think it's always wrong to build a shared pointer from a dead weak pointer, if it's then possible to check for a null value or do you see problems with this?</div></div><div class="gmail_extra"><br><div class="gmail_quote">2014-12-20 17:55 GMT+01:00 Cyrille Berger <span dir="ltr"><<a href="mailto:cberger@cberger.net" target="_blank">cberger@cberger.net</a>></span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">On Saturday 20 December 2014 13:58:57 Stefano Bonicatti wrote:<br>
> In general i think the same as him -><br>
> <a href="http://www.stroustrup.com/C++11FAQ.html#std-shared_ptr" target="_blank">http://www.stroustrup.com/C++11FAQ.html#std-shared_ptr</a>, not only because he<br>
> his who he his, but because it actually make sense what he says about<br>
> making the object lifetime cycle complex when shared pointer are used so<br>
> often.<br>
<br>
</span>The problem of Stroustrup is that he probably never was involved in a very<br>
large project involving many people who come and go during the years. So what<br>
he says, he is very sound and good at a theoretical level, and I would agree<br>
that in an ideal world I would follow what he says. And I do for small<br>
project. But Krita is 300k lines (or so) and had about 30 different developers<br>
working on it at different point of time. And not only the architecture has<br>
never been documented, it changes all the time, in such a situation, real life<br>
kicks in, and shared pointers are just better.<br>
<span class=""><br>
> Maybe having unique_ptr like pointers and shared pointer passed as const<br>
> references instead of raw pointer would be better,<br>
</span>Definitely better. But it make the code a bit less readable, unless you<br>
introduce a typedef. But is it worth the amount of work? (I guess it could be<br>
a new guideline).<br>
<span class=""><br>
> so that it's more<br>
> explicit the fact that you should not delete it manually and it's cheaper,<br>
> copy wise and with the ref/deref not happening when passed around in code<br>
> that shouldn't actually prolong its life.<br>
> You would still have shared pointers around but it would be much easier for<br>
> the memory leak tracker to keep track on who is really holding the memory.<br>
<br>
</span>When it comes to memory leak and optimisation, I always advise to first use a<br>
profiler to get information and then find solution. If it shows that their are<br>
actual (major) leak and that the referencing/derefencing is a problem. Because<br>
you may spend month trying to fix that doesn't change anything noticeable while<br>
in the same time you could have fixed actual problems.<br>
<span class=""><br>
> > The idea provided by Qt's shared pointers might be very helpful here<br>
><br>
> (Qt's weak shared pointer doesn't allow dereferencing the pointer until<br>
> upgrade to a real shared pointer)<br>
><br>
> There are a couple of problems with Krita weak pointers i'm facing though:<br>
> 1) If you pass a dead weak pointer to a shared pointer the check to see if<br>
> the weak pointer is valid is done in an assert only after the shared<br>
> pointers tries to increase the reference count.<br>
> This works if the weak pointer internal pointer was set to NULL, because<br>
> shared pointer ref() function checks for that, but if the weak pointer<br>
> points to deleted memory.. well ref() behaviour is undefined.<br>
<br>
</span>This is a bug, obviously. It should assert if the weak shared pointer is not<br>
valid.<br>
<div class="HOEnZb"><div class="h5"><br>
--<br>
Cyrille Berger Skott<br>
_______________________________________________<br>
Krita mailing list<br>
<a href="mailto:kimageshop@kde.org">kimageshop@kde.org</a><br>
<a href="https://mail.kde.org/mailman/listinfo/kimageshop" target="_blank">https://mail.kde.org/mailman/listinfo/kimageshop</a><br>
</div></div></blockquote></div><br></div>