我正在制作一个Java应用程序,它将数据自动发送到我的远程服务器。
我需要的是插入数据而不会感觉到最终用户的滞后。远程数据库更新部分应在后台运行。我尝试了swingworker,线程,但没有任何效果。仍然落后于我的应用。这是我到目前为止所做的

public class uploader extends Thread {

    static Socket socket;
    static Timer ttt;

    public void run() {
        try {
            ttt = new Timer(15000, new ActionListener() {
                @Override
                public void actionPerformed(ActionEvent e) {

                    try {

                        socket = new Socket("192.168.10.1", 3306);

//upload
                        ResultSet rs = DB.search("select query,id FROM general_log where state = 0 order by id asc");
                        while (rs.next()) {
                            try {
                                socket = new Socket("192.168.10.1", 3306);
                                DB2.acknowledge(rs.getString(1));
                                DB.acknowledge("update general_log set state = 1 where id = '" + rs.getString(2) + "'");

                            } catch (Exception e1) {
                                e1.printStackTrace();
                                System.out.println("error");
                                break;
                            }

                        }

                    } catch (Exception e3) {
                        System.out.println("error");
                        e3.printStackTrace();
                    }

                }
            });
            ttt.start();


        } catch (Exception e) {
            e.printStackTrace();

        }

    }

}


我在启动时运行

Thread upl = new Thread(new uploader());
upl.start();


每15秒本地数据应上载到远程服务器。但是在这里,我的用户界面在计时器运行时滞后15秒。

我该怎么做而不会造成延迟?
提前致谢。

最佳答案

可以肯定的是,您可以使用索引优化SQL查询。

除了关于主要问题之外,使用在new Handler()中启动的Timer Task更好吗?

==========================================

例如,代替类创建一个方法:

private final Handler handler = new Handler();
private TimerTask timerTask;
private Timer timer = new Timer();



...

    public void sendBackgroundData() {

    timerTask = new TimerTask() {
        @Override
        public void run() {
            handler.post(() -> {

DO YOUR CODE

                    }
            });
        }
    };
    timer.schedule(timerTask, 0, 2000);
}

10-05 20:47