```php
void Connection::close(mixed $data = '')
Fecha a conexão de forma segura e dispara o callback onClose da conexão.
Embora o udp seja sem conexão, o objeto correspondente AsyncUdpConnection permanece na memória até que o método close seja chamado para liberar o objeto da conexão udp correspondente; caso contrário, esse objeto de conexão udp permanecerá na memória, causando um vazamento de memória.
Parâmetros
$data
Parâmetro opcional, os dados a serem enviados (se houver um protocolo especificado, o método encode do protocolo será chamado automaticamente para embalar os dados $data), a conexão será fechada após os dados serem enviados, e então o callback onClose será disparado.
O tamanho dos dados não pode exceder 65507 bytes, caso contrário, o envio falhará.
Exemplo
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(){
// Após 1 segundo, inicia um cliente udp, conecta à porta 1234 e envia a string hi
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){
// Recebe os dados retornados do servidor hello
echo "recv $data\r\n";
// Fecha a conexão
$udp_connection->close();
};
$udp_connection->connect();
}, null, false);
};
$worker->onMessage = function(UdpConnection $connection, $data)
{
// Recebe os dados enviados pelo cliente AsyncUdpConnection e retorna a string hello
$connection->send("hello");
};
Worker::runAll();
Após a execução, imprime algo semelhante a:
recv hello