Server IP : 80.87.202.40 / Your IP : 216.73.216.169 Web Server : Apache System : Linux rospirotorg.ru 5.14.0-539.el9.x86_64 #1 SMP PREEMPT_DYNAMIC Thu Dec 5 22:26:13 UTC 2024 x86_64 User : bitrix ( 600) PHP Version : 8.2.27 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : ON Directory : /home/bitrix/ext_www/rospirotorg.ru/vendor/php-ds/php-ds/src/Traits/ |
Upload File : |
<?php namespace Ds\Traits; /** * Common to structures that require a capacity which is a power of two. */ trait SquaredCapacity { use Capacity; /** * Rounds an integer to the next power of two if not already a power of two. * * @param int $capacity * * @return int */ private function square(int $capacity): int { return pow(2, ceil(log($capacity, 2))); } /** * Ensures that enough memory is allocated for a specified capacity. This * potentially reduces the number of reallocations as the size increases. * * @param int $capacity The number of values for which capacity should be * allocated. Capacity will stay the same if this value * is less than or equal to the current capacity. */ public function allocate(int $capacity) { $this->capacity = max($this->square($capacity), $this->capacity); } /** * Called when capacity should be increased to accommodate new values. */ protected function increaseCapacity() { $this->capacity = $this->square( max( count($this) + 1, $this->capacity * $this->getGrowthFactor() ) ); } /** * @param int $total */ protected function ensureCapacity(int $total) { while ($total > $this->capacity()) { $this->increaseCapacity(); } } }