<table><tr><td style="">aaronpuchert added a comment.
</td><a style="text-decoration: none; padding: 4px 8px; margin: 0 8px 8px; float: right; color: #464C5C; font-weight: bold; border-radius: 3px; background-color: #F7F7F9; background-image: linear-gradient(to bottom,#fff,#f1f0f1); display: inline-block; border: 1px solid rgba(71,87,120,.2);" href="https://phabricator.kde.org/D9824" rel="noreferrer">View Revision</a></tr></table><br /><div><div><blockquote style="border-left: 3px solid #8C98B8;
color: #6B748C;
font-style: italic;
margin: 4px 0 12px 0;
padding: 8px 12px;
background-color: #F8F9FC;">
<div style="font-style: normal;
padding-bottom: 4px;">In <a href="https://phabricator.kde.org/D9824#192793" style="background-color: #e7e7e7;
border-color: #e7e7e7;
border-radius: 3px;
padding: 0 4px;
font-weight: bold;
color: black;text-decoration: none;" rel="noreferrer">D9824#192793</a>, <a href="https://phabricator.kde.org/p/rjvbb/" style="
border-color: #f1f7ff;
color: #19558d;
background-color: #f1f7ff;
border: 1px solid transparent;
border-radius: 3px;
font-weight: bold;
padding: 0 4px;" rel="noreferrer">@rjvbb</a> wrote:</div>
<div style="margin: 0;
padding: 0;
border: 0;
color: rgb(107, 116, 140);"><p>If real-world impact is in the order of a highly significant but millisecond-order reduction of reaction time to file change there may be little reason to commit this improvement now (and then risk forgetting about the rest again). My hunch is that it could be more effective then to keep this change pending and use it as a motivation to work on a more complete overhaul of the class.</p></div>
</blockquote>
<p>You know how they say, “perfect is the enemy of good.” Also we know at least one person that isn't going to forget about this, don't we? To keep an improvement — and you don't seem to dispute that it is an improvement — pending as “motivation to work on a more complete overhaul” is an argument I can't follow. I guess this is what Uncle Bob calls the <a href="http://www.informit.com/articles/article.aspx?p=1235624&seqNum=3" class="remarkup-link" target="_blank" rel="noreferrer">Grand Redesign in the Sky</a>.</p>
<blockquote style="border-left: 3px solid #8C98B8;
color: #6B748C;
font-style: italic;
margin: 4px 0 12px 0;
padding: 8px 12px;
background-color: #F8F9FC;">
<div style="font-style: normal;
padding-bottom: 4px;">In <a href="https://phabricator.kde.org/D9824#191203" style="background-color: #e7e7e7;
border-color: #e7e7e7;
border-radius: 3px;
padding: 0 4px;
font-weight: bold;
color: black;text-decoration: none;" rel="noreferrer">D9824#191203</a>, <a href="https://phabricator.kde.org/p/dfaure/" style="
border-color: #f1f7ff;
color: #19558d;
background-color: #f1f7ff;
border: 1px solid transparent;
border-radius: 3px;
font-weight: bold;
padding: 0 4px;" rel="noreferrer">@dfaure</a> wrote:</div>
<div style="margin: 0;
padding: 0;
border: 0;
color: rgb(107, 116, 140);"><p>I'm 100% sure the same rules applies, because the "limitations" of operator[] come from C++ and therefore apply to all associative containers.</p></div>
</blockquote>
<p>The limitation is that with <tt style="background: #ebebeb; font-size: 13px;">operator[]</tt> followed by an assignment the associated value is first value-initialized (here zero-initialized), before later the actual value is written. Since the value has type <tt style="background: #ebebeb; font-size: 13px;">Entry*</tt>, “a hair faster” is quite accurate. I doubt this is even measurable, taking into account the cost of allocation, computing the hash value, and possible cache misses, that are associated with adding a new element.</p>
<p>I'm not saying we shouldn't use <tt style="background: #ebebeb; font-size: 13px;">insert</tt>, but it's probably a micro-optimization.</p></div></div><br /><div><strong>REPOSITORY</strong><div><div>R244 KCoreAddons</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D9824" rel="noreferrer">https://phabricator.kde.org/D9824</a></div></div><br /><div><strong>To: </strong>mwolff, dfaure, rjvbb, KDevelop<br /><strong>Cc: </strong>aaronpuchert, bcooksley, zimmerman, markg, Frameworks<br /></div>