我的问题是,我有一个程序工作之前,没有线程,并花了很长时间来处理信息(16秒获取XML数据并显示它)。现在我已经完成了整个线程和异步的事情,但由于某种原因,它正在让我的程序变慢(在模拟器中,设备现在不可用),有没有我所做的任何事情可能造成这种情况, UI线程很好,但我的异步线程需要一分半钟才能执行。 (当我在UI线程有它用于拍摄只有16秒,但冻结UI线程)Asynctask采取荒谬的时间
这里是我的线程代码,它位于主类的内部:
private class TeamSearchTask extends AsyncTask<String,Void,String> {
CharSequence nfo;
String [] matches;
String [] data;
String teamNum;
ProgressDialog loading;
protected void onPreExecute()
{
//Show the 'loading' dialog
loading = new ProgressDialog(SapphireAlliance.this);
loading.setMessage("Loading, please wait...");
loading.show();
}
protected String doInBackground(String... teamNumber)
{
try
{
//Team information ------------------------------------------------------------------------------------
teamNum = teamNumber[0];
//Array of team data
data = APIconnection.getTeams(teamNum, "");
//Display basic team info
nfo = ("\nFormal Team Name:\n" + data[1] +
"\n\nLocation:\n" + data [3] + ", " + data[4] + ", " + data[5] +
"\n\nRookie Year:\n" + data[6] +
"\n\nRobot Name:\n" + data[7] +
"\n\nWebsite:\n" + data[8] + "\n\n\n\n\n\n\n\n\n");
//Make match archive --------------------------------------------------------------------------------------
String [] events = APIconnection.getEventIdsByYear(year1);
ArrayList<String> matches = new ArrayList<String>();
for (int i = 0; i<events.length; i++)
{
String [] add = APIconnection.getMatches2(teamNum, events[i] ,"","");
for(int j = 0; j<add.length; j++)
matches.add(add[j]);
}
String [] out = new String [matches.size()];
matches.toArray(out);
return "";
}
catch(Exception e)
{
return e.toString();
}
}
protected void onPostExecute(String result) {
if(result.equals(""))
{
info.setText(nfo);
matchArchive(matches);
//title
CharSequence ttl = "Team " + teamNum;
titlets.setText(ttl.toString());
loading.dismiss();
}
else
{
alert.setMessage(result);
alert.show();
}
}
}
什么在那里可能造成这种情况? :|
是的!这是第一场比赛! <3 xD 有没有办法提高优先级? 我的程序运行得非常好,其他时间很快,而且在UI线程中实际运行更快! – Nick 2010-10-12 04:32:22
嗯。我认为有一种方法可以为AsyncTask做到这一点,但我猜不是。我认为你真正的问题是要么连接到数据源,要么你如何解析XML。对于这种操作,主UI线程上16秒似乎有点慢。 – 2010-10-12 16:21:35
是因为我正在使用: javax.xml.parsers.DocumentBuilderFactory; javax.xml.parsers.DocumentBuilder; org.xml.sax.SAXException; org.xml.sax.SAXParseException; 那些而不是android.sax? – Nick 2010-10-12 21:36:27