On Fri, Apr 3, 2015 at 9:57 PM, Anthony Ferrara <ircmax...@gmail.com> wrote:

> All,
>
> I spent a little bit of time today trying to debug an issue with 7
> that Drupal 8 was facing, specifically regarding an array index not
> behaving correctly ($array["key"] returned null, even though the key
> existed in the hash table).
>
> I noticed that the hash table implementation has gotten orders of
> magnitude more complex in recent times (since phpng was merged).
>
> Specifically, that ardata and arhash are now the same block of memory,
> and that we're now doing negative indexing into arData to get the hash
> map list. From Dmitry's commit message, it was done to keep the data
> that's accessed most often in the same CPU cache line. While I am sure
> that there are definitive performance gains to doing this, I do worry
> about the development and debugging costs of this added complexity.
>
> As well as the way it increases the busfactor of the project.
>
> There is definitely a tradeoff there, as the change is pretty well
> encapsulated behind macros. But that introduces a new level of
> abstraction. But deeper than that it really makes debugging with gdb a
> pain in the neck.
>
> Without hard data on this particular patch, I'm not suggesting we roll
> back the change or anything. I more just want to express concern with
> the trend lately to increase complexity significantly on developers
> for the sake of performance.
>

> While I'm definitely not saying performance doesn't matter, I also
> think performance at all costs is dangerous. And I wonder if some of
> the more fundamental (even if isolated) changes such as this should be
> way more documented and include the performance justification for
> them. I'm definitely not suggesting an RFC, but perhaps some level of
> discussion should be required for these sorts of changes...
>

The idea was described months ago, then implemented part by part.

https://www.mail-archive.com/internals@lists.php.net/msg72362.html

Thanks. Dmitry.


>
> Thoughts?
>
> --
> PHP Internals - PHP Runtime Development Mailing List
> To unsubscribe, visit: http://www.php.net/unsub.php
>
>

Reply via email to