void Connection::close(mixed $data = '')

Bağlantıyı güvenli bir şekilde kapatın ve bağlantının onClose geri çağırmasını tetikleyin.

UDP bağlantısız bir protokoldür, ancak ilgili AsyncUdpConnection nesnesi hafızada tutulur. Bağlantıyı serbest bırakmak için close metodunun çağrılması gerekmektedir; aksi takdirde bu UDP bağlantı nesnesi hafızada kalmaya devam eder ve hafıza sızıntısına neden olur.

Parametreler

$data

Gönderilecek veriyi belirten isteğe bağlı bir parametre (belirli bir protokol tanımlandıysa, $data verilerini paketlemek için otomatik olarak protokolün encode metodu çağrılır). Veriler gönderildikten sonra bağlantı kapatılacak ve ardından onClose geri çağırması tetiklenecektir.

Veri boyutu 65507 bayttan büyük olamaz; aksi takdirde gönderim başarısız olur.

Örnek

use Workerman\Worker;
use Workerman\Timer;
use Workerman\Connection\AsyncUdpConnection;
use Workerman\Connection\UdpConnection;
require_once __DIR__ . '/vendor/autoload.php';

$worker = new Worker('udp://0.0.0.0:1234');
$worker->onWorkerStart = function(){
    // 1 saniye sonra bir UDP istemcisi başlatın, 1234 numaralı porta bağlanın ve 'hi' kelimesini gönderin
    Timer::add(1, function(){
        $udp_connection = new AsyncUdpConnection('udp://127.0.0.1:1234');
        $udp_connection->onConnect = function(AsyncUdpConnection $udp_connection){
            $udp_connection->send('hi');
        };
        $udp_connection->onMessage = function(AsyncUdpConnection $udp_connection, $data){
            // Sunucudan dönen veri hello
            echo "recv $data\r\n";
            // Bağlantıyı kapat
            $udp_connection->close();
        };
        $udp_connection->connect();
    }, null, false);
};
$worker->onMessage = function(UdpConnection $connection, $data)
{
    // AsyncUdpConnection istemcisinden gelen veriyi al, 'hello' stringini döndür
    $connection->send("hello");
};
Worker::runAll();             

Uygulandıktan sonra benzer bir çıktı verecektir:

recv hello