aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record/statement_cache.rb
diff options
context:
space:
mode:
authorschneems <richard.schneeman+foo@gmail.com>2018-09-20 23:09:10 -0500
committerschneems <richard.schneeman+foo@gmail.com>2018-09-21 17:33:17 -0500
commit6da99b4e99c90c63015f0d1cb4bf10983ea26a36 (patch)
treee8eb9495ea8d4dbdd89d0631e0ef9517343060b2 /activerecord/lib/active_record/statement_cache.rb
parenta44b7f180d0f03613479fb227d09ce2d7f74a187 (diff)
downloadrails-6da99b4e99c90c63015f0d1cb4bf10983ea26a36.tar.gz
rails-6da99b4e99c90c63015f0d1cb4bf10983ea26a36.tar.bz2
rails-6da99b4e99c90c63015f0d1cb4bf10983ea26a36.zip
Decrease memory allocations in cache.rb
The `merged_options` method is private and the output is never mutated. Using this info we can get rid of the `dup` behavior. We can also eliminate the `merge` call in the case where all the options being merged are the same. Returned results are frozen as an extra layer of protection against mutation. Before ``` Total allocated: 741749 bytes (6642 objects) ``` After ``` Total allocated: 734039 bytes (6648 objects) ``` Diff ``` (741749 - 734039) / 741749.0 => ~ 1.0 % ``` If you don't feel comfortable modifying this method, we could rename it and only use it internally.
Diffstat (limited to 'activerecord/lib/active_record/statement_cache.rb')
0 files changed, 0 insertions, 0 deletions