我正在制作一个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);
}