如何同步我的端口扫描程序,以便结果按照执行顺序显示?

时间:2012-12-21 06:24:32

标签: java multithreading

我创建了一个类,它将尝试扫描某个主机的端口。

问题在于我以随机的方式获得结果或首先完成w / e。

如何确保在执行此端口扫描时显示结果?

测试方法(对不起谷歌):

public class SimplePortScanner
{
    public static void main(String[] args)
    {
        for(int i = 78; i < 85; i++)
        {
            new Scanner("google.com", i).start();
        }
    }
}

端口扫描方法:

import java.net.*;

public class Scanner extends Thread
{
    private String address;
    private int port;

    Scanner(String address, int port)
    {
        super(address);
        this.address = address;
        this.port = port;
    }

    public void run()
    {
        try
        {
            SocketAddress sa = new InetSocketAddress(address, port);
            Socket socket = new Socket();
            socket.connect(sa, 2000);

            System.out.println("Port in use: " + port);

            socket.close();
        }
        catch (Exception e)
        {
            System.out.println("Port not in use: " + port);
        }
    }
}

我正在考虑创建一个线程编号并将结果保存在数组中以便执行它们(至少我在脑海中看到的是这样)。

如何正确执行此操作?我只是搞乱线程,很抱歉,如果我在这里搞乱了......

1 个答案:

答案 0 :(得分:2)

尝试java.util.concurrent

class Scanner implements Callable<Boolean> {
    ....

    @Override
    public Boolean call() {
        try {
            ....
            return true;
        } catch(Exception e) {
            return false;
        }
    }
}

ExecutorService ex = Executors.newCachedThreadPool();
List<Scanner> tasks = new ArrayList<>();
for (int i = 78; i < 85; i++) {
    tasks.add(new Scanner("google.com", i));
}
List<Future<Boolean>> list = ex.invokeAll(tasks);
for(int i = 0; i < tasks.size(); i++) {
    if (list.get(i).get()) {
        System.out.printf("Port is in use: %d", tasks.get(i).port());
    } else {
        System.out.printf("Port is not in use: %d", tasks.get(i).port());
    }
}
// dont forget to shutdown executor
ex.shutdown();