У меня есть простой UDP-сервер, который создает новый поток для обработки входящих данных. При тестировании, отправляя около 100 пакетов в секунду, я замечаю, что его использование памяти продолжает расти Есть ли какие-либо утечки из моего кода ниже?
Вот код для сервера.
public class UDPServer
{
public static void main(String[] args)
{
UDPServer server = new UDPServer(15001);
server.start();
}
private int port;
public UDPServer(int port)
{
this.port = port;
}
public void start()
{
try
{
DatagramSocket ss = new DatagramSocket(this.port);
while(true)
{
byte[] data = new byte[1412];
DatagramPacket receivePacket = new DatagramPacket(data, data.length);
ss.receive(receivePacket);
new DataHandler(receivePacket.getData()).start();
}
}
catch (IOException e)
{
e.printStackTrace();
}
}
}
Вот код для нового потока, который обрабатывает данные. Пока что метод run () ничего не делает.
public class DataHandler extends Thread
{
private byte[] data;
public DataHandler(byte[] data)
{
this.data = data;
}
@Override
public void run()
{
System.out.println("run");
}
}