驴Por qu茅 necesitamos est谩tica al declarar funciones an贸nimas?

El otro d铆a me lleg贸 una pregunta de uno de los suscriptores sobre una de las publicaciones de mi canal de telegramas . Estaba confundido por este c贸digo.





<?php

usort($firstArray, static function($first, $second) {
    return $first <=> $second;
});
      
      



La pregunta sonaba as铆:





驴Por qu茅 hacer que las devoluciones de llamada usort sean est谩ticas?





Y pens茅 que esta es una buena pregunta a la que prestar atenci贸n.





驴Cu谩l es el problema?

Comencemos con la definici贸n de la documentaci贸n para sincronizar:





Las funciones an贸nimas, tambi茅n conocidas como cierres , le permiten crear funciones que no tienen un nombre espec铆fico. Son m谩s 煤tiles como valores de  par谩metros invocables , pero tambi茅n pueden tener muchos otros usos.





Las funciones an贸nimas se implementan utilizando la clase  Closure .





Ah铆, pero casi nadie lee esto:





Cuando se declara en el contexto de una clase, la clase actual se asociar谩 autom谩ticamente con ella, haciendo que $ this est茅 disponible dentro de las funciones de la clase. Si no desea vincularse autom谩ticamente a la clase actual, use funciones an贸nimas est谩ticas .





, losure , . , $this



:





,
<?php

class ExampleTest extends TestCase
{
 
    public function testBasicTest(): void
    {
        $array = [2, 1];
        usort($array, function ($first, $second) {
            var_dump($this);
            return $first <=> $second;
        });

     	  self::assertTrue(true);
    }

}
      
      



" ", .





, $this, , , , .





static:





<?php 

class LargeObject {
    protected $array;

    public function __construct() {
        $this->array = array_fill(0, 2000, 15);
    }

    public function getItemProcessor(): Closure {
        return function () { //    
            $a = 1;
            $b = 2;
            return $a + $b;
        };
    }
}

function getPeakMemory(): string
{
    return sprintf('%.2F MiB', memory_get_peak_usage() / 1024 / 1024);
}
$start = microtime(true);

$processors = [];
for ($i = 0; $i < 2000; $i++) {
    $lo = new LargeObject();
    $processors[] = $lo->getItemProcessor();
}

var_dump(getPeakMemory());

      
      



, string(10) "134.10 MiB"







, static 11 , string(8) "1.19 MiB"







, processors[]



, losures , , , .





, static . static, , .





P.S.

. - https://t.me/beerphp. .








All Articles