2010-10-12 60 views
1

我的问题是,我有一个程序工作之前,没有线程,并花了很长时间来处理信息(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(); 
     } 
    } 
} 

什么在那里可能造成这种情况? :|

回答

0

这可能是因为您的线程优先级可能不会很高。我记得默认值很低。但是,对于你正在做的事情,它不应该花费几秒钟。我认为真正的问题在于API连接到网络上并做了需要很长时间的事情。特别是,如果每次调用打开一个新的套接字,那么执行事件获取的那个for循环将会做很多工作,假设这是用于FIRST匹配的。 :P

+1

是的!这是第一场比赛! <3 xD 有没有办法提高优先级? 我的程序运行得非常好,其他时间很快,而且在UI线程中实际运行更快! – Nick 2010-10-12 04:32:22

+0

嗯。我认为有一种方法可以为AsyncTask做到这一点,但我猜不是。我认为你真正的问题是要么连接到数据源,要么你如何解析XML。对于这种操作,主UI线程上16秒似乎有点慢。 – 2010-10-12 16:21:35

+0

是因为我正在使用: 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

0

我有同样的问题,没有什么比使用简单的DES解密文件副本...整个事情在几秒钟内在UI线程上运行,但是当移到ASYNCTASK中时,它现在正在MINUTES完成。难以置信的。

相关问题