与背景线程的混乱

时间:2013-05-12 15:26:01

标签: android multithreading android-asynctask background-thread

我有两个AsyncTasks,一个用于下载xml文件(DownloadTask),另一个用于解析文件(ParseXMLTask)。 有两种情况使用此任务:

1)文件不存在>执行DownloadTask,onPostExecute> ParseXMLTask

2)文件存在>只执行ParseXMLTask。

一切正常,但问题是,在执行第二种情况时,会阻止ui大约3秒(黑屏)肯定会让用户恼火。这让我感到很困惑,因为第二种情况下的工作似乎更容易。

因此,当我测试我的应用时,情况就是这样:我第一次点击按钮,正在下载文件,保存在SD卡上,解析并最终打开。然后我回去再次点击按钮。现在,我在活动之间切换时看到了延迟。

代码:

执行任务

private void downloadPack() {
    if (packDownloaded) {
        parseXML();
    } else {    
        download = new DownloadFile(fileName, this, loadingBar);
        download.execute(serverURL + fileName + ".xml");
    }
}

private void parseXML() {
    ParseXMLTask parseTask = new ParseXMLTask(this, this);
    parseTask.execute(PATH + fileName + ".xml");
}

public void postDownload(File result) {
        parseXML();     
}   

public void postParse() {               
    Intent packIntent = new Intent(this, PackActivity.class);
    startActivity(packIntent);      
}

ParseXMLTask.java

public class ParseXMLTask extends AsyncTask<String, Integer, Void> {    

private Context context;
private XmlPullParser xpp;
private IPostParse iPostParse;

public ParseXMLTask(Context context, IPostParse iPostParse) {
    this.context = context;
    this.iPostParse = iPostParse;

}

@Override
protected Void doInBackground(String... params) {               
    File file = new File(params[0]);

    /* doing the job */
}

@Override
protected void onPostExecute(Intent result) {
    iPostParse.postParse(result);
}
}

DownloadFile.java

public class DownloadFile extends AsyncTask<String, Integer, File> {

private static final String PATH = Environment
        .getExternalStorageDirectory().getPath() + "/.chgkgame/";;
private File dir;
private ProgressBar progressBar;
private String fileName;
private IPostDownload postDownload;
private boolean download;


public DownloadFile(String name, IPostDownload pDownload, ProgressBar pBar) {
    progressBar = pBar;
    fileName = name;
    postDownload = pDownload;
}


@Override
protected File doInBackground(String... sUrl) {
    URL url;
    try {
        url = new URL(sUrl[0]);
        URLConnection urlConnection = url.openConnection();
        urlConnection.connect();            
        int fileLength = urlConnection.getContentLength();

        dir = new File(PATH + fileName + ".xml");
        InputStream input = new BufferedInputStream(url.openStream());
        OutputStream output = new FileOutputStream(dir);

        byte[] data = new byte[1024];
        long total = 0;
        int count;
        while ((count = input.read(data)) != -1) {
            total += count;
            publishProgress((int) (total * 100 / fileLength));
            output.write(data, 0, count);
        }

        output.flush();
        output.close();
        input.close();
    } catch (MalformedURLException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }

    return dir;
}

@Override 
protected void onPostExecute(File result) {
    if (postDownload != null) postDownload.postDownload(result);
}

@Override
protected void onProgressUpdate(Integer... values) {
    super.onProgressUpdate(values);

    if (progressBar != null) {
        progressBar.setProgress(values[0]);
    }
}
}

1 个答案:

答案 0 :(得分:0)

上面没有任何问题。

解析非常快,这就是为什么你只能看到一瞬间的布局。

黑屏将为PackActivity加载,检查此活动以阻止UI线程。

您还可以将LogCat消息放入以显示解析已完成并调用下一个Activity的onCreate。