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

연결을 안전하게 닫고, 연결의 ```onClose``` 콜백을 트리거합니다.

비록 udp는 비연결성이지만, 해당 AsyncUdpConnection 객체는 메모리에서 계속 유지됩니다. close 메서드를 호출해야 해당 udp 연결 객체를 해제할 수 있으며, 그렇지 않으면 이 udp 연결 객체는 메모리에 계속 남아 메모리 누수를 초래합니다.

## 매개변수

 ``` $data ```

선택적 매개변수로, 전송할 데이터입니다(프로토콜이 지정된 경우, 프로토콜의 encode 메서드가 자동으로 호출되어 ```$data``` 데이터를 패킹합니다). 데이터 전송이 완료된 후 연결을 닫고, 이어서 onClose 콜백이 트리거됩니다.

데이터의 크기는 65507 바이트를 초과할 수 없으며, 그렇지 않으면 전송 실패합니다.

### 예제

```php
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초 후에 udp 클라이언트를 시작하여 1234 포트에 연결하고 문자열 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){
            // 서버에서 반환된 데이터 hello를 수신합니다.
            echo "recv $data\r\n";
            // 연결을 닫습니다.
            $udp_connection->close();
        };
        $udp_connection->connect();
    }, null, false);
};
$worker->onMessage = function(UdpConnection $connection, $data)
{
    // AsyncUdpConnection 클라이언트가 보낸 데이터를 수신하여 문자열 hello를 반환합니다.
    $connection->send("hello");
};
Worker::runAll();             

실행 후 출력 결과:

recv hello